PHP模板引擎 Smarty 程序設計部分 基礎說明

PHP模板引擎 Smarty

smarty是一個基於PHP開發的PHP模板引擎。它提供了邏輯與外在內容的分離,簡單的講,目的就是要使 用PHP程序員同美工分離,使用的程序員改變程序的邏輯內容不會影響到美工的頁面設計,美工重新修改頁面不會影響到程序的程序邏輯,這在多人合作的項目中 顯的尤爲重要。

smarty的程序設計部分  index.php PHP代碼

<?php 
/** 

* @version $Id: index.php 
* @package 
* @author www.php100.com 
* @action 顯示實例程序 
*/ 
include_once("./Smarty/Smarty.class.php"); //包含smarty類文件 

$smarty = new Smarty(); //建立smarty實例對象$smarty 
$smarty->templates("./templates"); //設置模板目錄 
$smarty->templates_c("./templates_c"); //設置編譯目錄 
$smarty->cache("./cache"); //緩存目錄 
$smarty->cache_lifetime = 0; //緩存時間 
$smarty->caching = true; //緩存方式 

$smarty->left_delimiter = "{#"; 
$smarty->right_delimiter = "#}"; 
$smarty->assign("name", "zaocha"); //進行模板變量替換 
$smarty->display("index.htm"); //編譯並顯示位於./templates下的index.htm模板 
?> 


////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////


/*  */語句 註釋

include_once語句 包含到當前文件

$smarty = new Smarty():新建一個Smarty對象

$smarty->templates(""):指明$smarty對象使用tpl模板時的路徑,它是一個目錄,在沒有這一句時,Smarty默認的模板路徑爲當前目錄的templates目錄。

$smarty->templates_c(""):  指明$smarty對象進行編譯時的目錄

$smarty->left_delimiter與$smarty->right_delimiter:
指明在查找模板變量時的左右分割符。默認情況下爲"{"與"}",但在實際中因爲我們要在模板中使用<script>,Script中的函數定義難免會使用{},雖然它有自己的解決辦法,但習慣上我們將它重新定義爲"{#"與"#}"或是"<!--{"與"}-->"或其它標誌符,注意,如果在這裏定義了左右分割符後,在模板文件中相應的要使每一個變量使用與定義相同的符號,例如在這裏指定爲"<{"與"}>",htm模板中也要相應的將{$name}變成<{$name}>,這樣程序纔可以正確的找到模板變量。

$smarty->cache("./cache"):Smarty輸出的模板文件緩存的位置,默認情況下爲當前目錄下的cache目錄。

$smarty->cache_lifetime = 60 * 60 * 24:
這裏將以秒爲單位進行計算緩存有效的時間。
第一次緩存時間到期時當Smarty的caching變量設置爲true時緩存將被重建。
當它的取值爲-1時表示建立起的緩存從不過期,
爲0時表示在程序每次執行時緩存總是被重新建立。
上面的設置表示將cache_lifetime設置爲一天。


 $smarty->caching = 1:
這個屬性告訴Smarty是否要進行緩存以及緩存的方式。它可以取3個值,
0:Smarty默認值,表示不對模板進行緩存;
1:表示Smarty將使用當前定義的cache_lifetime來決定是否結束cache;
2:表示Smarty將使用在cache被建立時使用cache_lifetime這個值。
習慣上使用true與false來表示是否進行緩存。

$smarty->assign("name", "zaocha"):
該數的原型爲assign(string varname, mixed var),varname爲模板中使用的模板變量,var指出要將模板變量替換的變量名;其第二種原形爲assign(mixed var),我們要在後面的例子詳細的講解這個成員函數的使用方法,assign是Smarty的核心函數之一,所有對模板變量的替換都要使用它。

$smarty->display("index.tpl"):
該函數原形爲display(string varname),作用爲顯示一個模板。簡單的講,它將分析處理過的模板顯示出來,這裏的模板文件不用加路徑,只要使用一個文件名就可以了,它路徑我們已經在$smarty->templates(string path)中定義過了。


程序執行完後我們可以打開當前目錄下的templates_c與cache目錄,就會發現在下邊多出一些%%的目錄,這些目錄就是Smarty的編譯與緩存目錄,它由程序自動生成不要直接對這些生成的文件進行修改

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