php-smarty

  1. 一:smarty的程序設計部分: 
  2. 在smarty的模板設計部分我簡單的把smarty在模板中的一些常用設置做了簡單的介紹,這一節主要來介紹一下如何在smarty中開始我們程序設計。下載Smarty文件放到你們站點中。 
  3. index.php PHP代碼: 
  4. <?php 
  5. /** 
  6. * @version   $Id: index.php 
  7. * @package 
  8. * @author www.php100.com 
  9. * @action   顯示實例程序 
  10. */ 
  11. include_once("./Smarty/Smarty.class.php"); //包含smarty類文件 
  12. $smarty = new Smarty(); //建立smarty實例對象$smarty 
  13. $smarty->templates("./templates"); //設置模板目錄 
  14. $smarty->templates_c("./templates_c"); //設置編譯目錄 
  15. $smarty->cache("./cache"); //緩存目錄 
  16. $smarty->cache_lifetime = 0; //緩存時間 
  17. $smarty->caching = true; //緩存方式 
  18. $smarty->left_delimiter = "{#"
  19. $smarty->right_delimiter = "#}"
  20. $smarty->assign("name", "zaocha"); //進行模板變量替換 
  21. $smarty->display("index.htm"); //編譯並顯示位於./templates下的index.htm模板 
  22. ?> 
  23. 二:解釋smarty的程序 
  24. 我們可以看到,smarty的程序部分實際就是符合php語言規範的一組代碼,我們依次來解釋一下: 
  25. 1:/**/語句: 
  26. 包含的部分爲程序篇頭註釋。主要的內容應該爲對程序的作用,版權與作者及編寫時間做一個簡單的介紹,這在smarty中不是必需的,但從程序的風格來講,這是一個好的風格。 
  27. 2:include_once語句: 
  28. 它將安裝到網站的smarty文件包含到當前文件中,注意包含的路徑一定要寫正確。 
  29. 3:$smarty = new Smarty(): 
  30. 這一句新建一個Smarty對象$smarty,簡單的一個對象的實例化。 
  31. 4:$smarty->templates(""): 
  32. 這一句指明$smarty對象使用tpl模板時的路徑,它是一個目錄,在沒有這一句時,Smarty默認的模板路徑爲當前目錄的templates目錄,實際在寫程序時,我們要將這一句寫明,這也是一種好的程序風格。 
  33. 5:$smarty->templates_c(""): 
  34. 這一句指明$smarty對象進行編譯時的目錄。在模板設計篇我們已經知道Smarty是一種編譯型模板語言,而這個目錄,就是它編譯模板的目錄,要注意,如果站點位於linux服務器上,請確保 
  35. teamplates_c裏定義的這個目錄具有可寫可讀權限,默認情況下它的編譯目錄是當前目錄下的templates_c,出於同樣的理由我們將其明確的寫出來。 
  36. 6:$smarty->left_delimiter與$smarty->right_delimiter: 
  37. 指明在查找模板變量時的左右分割符。默認情況下爲"{"與"}",但在實際中因爲我們要在模板中使用<script>,Script中的函數定義難免會使用{},雖然它有自己的解決辦法,但習慣上我們將它重新定義 
  38. 爲"{#"與"#}"或是"<!--{"與"}-->"或其它標誌符,注意,如果在這裏定義了左右分割符後,在模板文件中相應的要使每一個變量使用與定義相同的符號,例如在這裏指定爲"<{"與"}>",htm模板中也要 
  39. 相應的將{$name}變成<{$name}>,這樣程序纔可以正確的找到模板變量。 
  40. 7:$smarty->cache("./cache"): 
  41. 告訴Smarty輸出的模板文件緩存的位置。上一篇我們知道Smarty最大的優點在於它可以緩存,這裏就是設置緩存的目錄。默認情況下爲當前目錄下的cache目錄,與templates_c目錄相當,在linux系統中 
  42. 我們要確保它的可讀可寫性。 
  43. 8: $smarty->cache_lifetime = 60 * 60 * 24: 
  44. 這裏將以秒爲單位進行計算緩存有效的時間。第一次緩存時間到期時當Smarty的caching變量設置爲true時緩存將被重建。當它的取值爲-1時表示建立起的緩存從不過期,爲0時表示在程序每次執行時緩 
  45. 存總是被重新建立。上面的設置表示將cache_lifetime設置爲一天。 
  46. 9: $smarty->caching = 1
  47. 這個屬性告訴Smarty是否要進行緩存以及緩存的方式。它可以取3個值,0:Smarty默認值,表示不對模板進行緩存;1:表示Smarty將使用當前定義的cache_lifetime來決定是否結束cache;2:表示 
  48. Smarty將使用在cache被建立時使用cache_lifetime這個值。習慣上使用true與false來表示是否進行緩存。 
  49. 10:$smarty->assign("name", "zaocha"): 
  50. 該數的原型爲assign(string varname, mixed var),varname爲模板中使用的模板變量,var指出要將模板變量替換的變量名;其第二種原形爲assign(mixed var),我們要在後面的例子詳細的講解這個成員函數的使用方法,assign是Smarty的核心函數之一,所有對模板變量的替換都要使用它。 
  51. 11. $smarty->display("index.tpl"): 
  52. 該函數原形爲display(string varname),作用爲顯示一個模板。簡單的講,它將分析處理過的模板顯示出來,這裏的模板文件不用加路徑,只要使用一個文件名就可以了,它路徑我們已經在$smarty->templates(string path)中定義過了。 
  53. 程序執行完後我們可以打開當前目錄下的templates_c與cache目錄,就會發現在下邊多出一些%%的目錄,這些目錄就是Smarty的編譯與緩存目錄,它由程序自動生成,不要直接對這些生成的文件進行修改。 
  54. 以上我簡單的把Smarty程序中的一些常用的基本元素介紹了一下,在後邊的例子中你可以看到將它們將被多次的使用。 
  55.  
  56. 三:模板說明 
  57.  
  58. 接下來介紹一個section循環塊與foreach循環塊,本來它應該屬於模板部分,但是由於它們是smarty的精華所在,而且與smarty程序設計部分聯繫非常緊密,所以就在本節單獨拿出來講一下。 
  59.  
  60. 1: foreach:用於循環簡單數組,它是一個選擇性的section循環,它的定義格式爲: 
  61.  
  62.  
  63.  
  64. {foreach from=$array item=array_id}  
  65. {foreachelse}  
  66. {/foreach} 
  67.  
  68.  
  69. 其中,from 指出要循環的數組變量,item爲要循環的變量名稱,循環次數由from所指定的數組變量的個數所決定。{foreachelse}用來當程序中傳遞過來的數組爲空時的處理,下面是一個簡單的例子: 
  70.  
  71. 模板文件:example.htm 
  72.  
  73. foreach 輸出一個“二維關聯數組”的數據: 
  74.  
  75.  
  76.  
  77. {#foreach item=new from=$news#}  
  78.  
  79. 新聞編號:{#$new.id#}  
  80.  
  81. 新聞內容:{#$new.title#}  
  82.  
  83. {#foreachelse#} 
  84.  
  85.  
  86. 數據庫中沒有新聞輸出! 
  87.  
  88.  
  89.  
  90. {#/foreach#}  
  91.  
  92. {foreach from=$newsArray item=newsID
  93.  
  94.  
  95.  
  96.  
  97. 新聞編號:{$newsID} 
  98.  
  99.  
  100.  
  101.  
  102. 新聞內容:{$newsTitle} 
  103.  
  104.  
  105.  
  106.  
  107. {foreachelse} 
  108.  
  109.  
  110. 對不起,數據庫中沒有新聞輸出! 
  111.  
  112.  
  113.  
  114. {/foreach} 
  115.  
  116.  
  117. 這是一個錯誤的不顯示數據,本文做了更正。 
  118.  
  119. 程序文件:example.php 
  120.  
  121.  
  122.  
  123. <?  
  124. /*********************************************  
  125. *  
  126. * 文件名: example.php  
  127. * 作 用: 顯示實例程序2  
  128. *********************************************/  
  129.  
  130. include_once("./Smarty/Smarty.class.php");  
  131.  
  132. $smarty = new Smarty();  
  133.  
  134. $smarty->templates("./templates");  
  135.  
  136. $smarty->templates_c("./templates_c");  
  137.  
  138. $smarty->cache("./cache");  
  139.  
  140. $smarty->cache_lifetime = 0;  
  141.  
  142. $smarty->caching = true;  
  143.  
  144. $smarty->left_delimiter = "{#";  
  145.  
  146. $smarty->right_delimiter = "#}";  
  147.  
  148. $array[] = array("newsID"=>1, "newsTitle"=>"第1條新聞");  
  149.  
  150. $array[] = array("newsID"=>2, "newsTitle"=>"第2條新聞");  
  151.  
  152. $array[] = array("newsID"=>3, "newsTitle"=>"第3條新聞");  
  153.  
  154. $array[] = array("newsID"=>4, "newsTitle"=>"第4條新聞");  
  155.  
  156. $array[] = array("newsID"=>5, "newsTitle"=>"第5條新聞");  
  157.  
  158. $array[] = array("newsID"=>6, "newsTitle"=>"第6條新聞");  
  159.  
  160. //這是一個二維關聯數組  
  161.  
  162. $smarty->assign("newsArray", $array);  
  163.  
  164. //編譯並顯示位於./templates下的index.htm模板  
  165.  
  166. $smarty->display("example.htm");  
  167.  
  168. ?> 
  169. 輸入結果:example.php 
  170.  
  171. 這裏將輸出一個數組: 
  172.  
  173.  
  174.  
  175. 新聞編號:1  
  176.  
  177. 新聞內容:第1條新聞  
  178.  
  179. 新聞編號:2  
  180.  
  181. 新聞內容:第2條新聞  
  182.  
  183. 新聞編號:3  
  184.  
  185. 新聞內容:第3條新聞  
  186.  
  187. 新聞編號:4  
  188.  
  189. 新聞內容:第4條新聞  
  190.  
  191. 新聞編號:5  
  192.  
  193. 新聞內容:第5條新聞  
  194.  
  195. 新聞編號:6  
  196.  
  197. 新聞內容:第6條新聞 
  198.  
  199.  
  200. foreach還可以用foreachelse來匹配,用foreachelse來表示當傳遞給foreach的數組爲空值時程序要執行的操作,具體的使用方法,請參考手冊的說明。 
  201.  
  202. 2. section: 
  203.  
  204. section的產生是爲解決foreach的不足的,與foreach一樣,它用於設計模板內的循環塊,它較爲複雜,可極大程序上滿足程序需要,所以在程序中我習慣使用它而不使用foreach,基本原形爲: 
  205.  
  206.  
  207.  
  208. {section namename = name loop = $varName[, start = $start, step = $step, max = $max, show = true]} 
  209.  
  210.  
  211.  
  212.  
  213. name: section的名稱,不用加$  
  214.  
  215. $loop: 要循環的變量,在程序中要使用assign對這個變量進行操作。  
  216.  
  217. $start: 開始循環的下標,循環下標默認由0開始  
  218.  
  219. $step: 每次循環時下標的增數  
  220.  
  221. $max: 最大循環下標  
  222.  
  223. $show: boolean類型,決定是否對這個塊進行顯示,默認爲true 
  224.  
  225.  
  226. 這裏有個名詞需要說明: 
  227.  
  228. 循環下標:實際它的英文名稱爲index,是索引的意思,這裏我將它譯成"下標",主要是爲了好理解。它表示在顯示這個循環塊時當前的循環索引,默認從0開始,受$start的影響,如果將$start設爲5,它也將從5開始計數,在模板設計部分我們使用過它,這是當前{section}的一個屬性,調用方式爲Smarty.section.sectionName.index,這裏的sectionName指的是函數原型中的name屬性。 
  229.  
  230. {section}塊具有的屬性值,分別爲: 
  231.  
  232. 1. index: 上邊我們介紹的"循環下標",默認爲0 
  233.  
  234. 2. index_prev: 當前下標的前一個值,默認爲-1 
  235.  
  236. 3. index_next: 當前下標的下一個值,默認爲1 
  237.  
  238. 4. first: 是否爲第一下循環 
  239.  
  240. 5. last: 是否爲最後一個循環 
  241.  
  242. 6. iteration: 循環次數 
  243.  
  244. 7. rownum: 當前的行號,iteration的另一個別名 
  245.  
  246. 8. loop: 最後一個循環號,可用在section塊後統計section的循環次數 
  247.  
  248. 9. total: 循環次數,可用在section塊後統計循環次數 
  249.  
  250. 10. show: 在函數的聲明中有它,用於判斷section是否顯示 
  251.  
  252. 它們的具體屬性大家可以參考手冊,在程序中可靈活使用它的這些屬性,模板部分我就使用過index屬性,大家可以回過頭去看看。 
  253.  
  254. 同樣,{section}也可以配合使用{sectionelse},用來表示傳入的數組變量爲空時對模板進行的處理。 
  255.  
  256. 我們把上邊的那個例子使用{section}來替代{foreach}來實現現樣的功能,注意,在這個例子中我只將tpl模板中的{foreach}用{section}來實現,php程序文件中沒有任何改動,同時加了{sectionelse}處理塊: 
  257.  
  258. example.tpl 
  259.  
  260. 這裏將輸出一個數組: 
  261.  
  262. {section name=loop loop=$News}  
  263. 新聞編號:{$News[loop].newsID}  
  264. 新聞標題:{$News[loop].newsTitle}  
  265. {sectionelse}  
  266. 對不起,沒有任何新聞輸入!  
  267. {/section} 
  268. example.php 
  269.  
  270. <?  
  271. /*********************************************  
  272.  
  273. *  
  274.  
  275. * 文件名: example7.php  
  276.  
  277. * 作 用: 顯示實例程序2  
  278.  
  279. *********************************************/  
  280.  
  281. include_once("./comm/Smarty.class.php");  
  282.  
  283. $smarty = new Smarty();  
  284.  
  285. $smarty->templates("./templates");  
  286.  
  287. $smarty->templates_c("./templates_c");  
  288.  
  289. $smarty->cache("./cache");  
  290.  
  291. $smarty->cache_lifetime = 0;  
  292.  
  293. $smarty->caching = true;  
  294.  
  295. $smarty->left_delimiter = "{";  
  296.  
  297. $smarty->right_delimiter = "}";  
  298.  
  299. $array[] = array("newsID"=>1, "newsTitle"=>"第1條新聞");  
  300.  
  301. $array[] = array("newsID"=>2, "newsTitle"=>"第2條新聞");  
  302.  
  303. $array[] = array("newsID"=>3, "newsTitle"=>"第3條新聞");  
  304.  
  305. $array[] = array("newsID"=>4, "newsTitle"=>"第4條新聞");  
  306.  
  307. $array[] = array("newsID"=>5, "newsTitle"=>"第5條新聞");  
  308.  
  309. $array[] = array("newsID"=>6, "newsTitle"=>"第6條新聞");  
  310.  
  311. $smarty->assign("newsArray", $array);  
  312.  
  313. //編譯並顯示位於./templates下的index.tpl模板  
  314.  
  315. $smarty->display("example.tpl");  
  316.  
  317. ?> 
  318. example.php 輸出文件 
  319.  
  320. 這裏將輸出一個數組:  
  321.  
  322. 新聞編號:1  
  323.  
  324. 新聞內容:第1條新聞  
  325.  
  326. 新聞編號:2  
  327.  
  328. 新聞內容:第2條新聞  
  329.  
  330. 新聞編號:3  
  331.  
  332. 新聞內容:第3條新聞  
  333.  
  334. 新聞編號:4  
  335.  
  336. 新聞內容:第4條新聞  
  337.  
  338. 新聞編號:5  
  339.  
  340. 新聞內容:第5條新聞  
  341.  
  342. 新聞編號:6  
  343.  
  344. 新聞內容:第6條新聞 
  345. 這裏的{section}塊的對於變量的命名方式感覺有些彆扭,不過沒關係,你只要記住模板變量使用: 
  346.  
  347. $loopName[name].var這種模式就行了,loopName爲loop處賦予的變量名,[name]爲name處賦予的字符串,.後爲爲你要在程序數組中設定要與值相對應的下標名稱就行了。 
  348.  
  349. 好了,smarty學習指南---程序設計篇就寫到這裏,對於一般的應用,這些知識已經夠用了,其它的一些高級技巧大家請參看手冊中的例子,下一節將講講Smarty在實際應用中的例子,將分別以php內置的mysql語句,phplib中的DB類,ADODB,Pear中DB類來分別講一下各個類庫在同一個例子中的實現。 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章