本文實例講述了ThinkPHP模板之變量輸出、自定義函數與判斷語句用法。主要包括變量輸出、自定義函數與判斷語句三種用法。分享給大家供大家參考。具體分析如下:
模板操作變量輸出:
快捷輸出變量
復制代碼 代碼如下:{:function(…)} //執行方法並輸出返回值
{~function} //執行方法不輸出
{@var} //輸出Session變量
{#var} //輸出Cookie變量
{&var} //輸出配置參數
{%var} //輸出語言變量
{.var} //輸出GET變量
{^var} //輸出POST變量
{*var} //輸出常量
模版輸出
復制代碼 代碼如下://1 直接調用index操作模板
$this->display();
// 對應Myapp/Tpl/default/Index/index.html
//2 調用Index模塊的test1操作模板
$this->display('test1');
//對應Myapp/Tpl/default/Index/test1.html
//2 調用Message模塊的test2操作模板()
$this->display('Message:test2');
//對應Myapp/Tpl/default/Message/test2.html
//3 調用XP主題的Message模塊的test2操作模板
$this->display('Xp@Message:test2');
//對應Myapp/Tpl/Xp/Message/test2.html
//4 直接指定模板文件的全名
$this->display('../Message/test3.html');
//對應Myapp/Tpl/default/Message/test3.html
使用判斷語句
我們可以使用if標簽來定義復雜的條件判斷,例如:
復制代碼 代碼如下:<if condition="($name eq 1) OR ($name gt 100) "> value1
<elseif condition="$name eq 2" />value2
<else /> value3
</if>
在condition屬性中可以支持eq等判斷表達式 ,同上面的比較標簽,但是不支持帶有”>”、”<”等符號的用法,因為會混淆模板解析,所以下面的用法是錯誤的:
<if condition="$id < 5 "> value1
<else /> value2
</if>
必須改成:
復制代碼 代碼如下:<if condition="$id lt 5 "> value1
<else /> value2
</if>
除此之外,我們可以在condition屬性裡面使用php代碼,例如:
復制代碼 代碼如下:<if condition="strtoupper($user['name']) neq 'THINKPHP' "> ThinkPHP
<else /> other Framework
</if>
condition屬性可以支持點語法和對象語法,例如:
自動判斷user變量是數組還是對象
復制代碼 代碼如下:<if condition="$user.name neq 'ThinkPHP' "> ThinkPHP
<else /> other Framework
</if>
或者知道user變量是對象
復制代碼 代碼如下:<if condition="$user:name neq 'ThinkPHP' "> ThinkPHP
<else /> other Framework
</if>
由於if標簽的condition屬性裡面基本上使用的是php語法,盡可能使用判斷標簽和Switch標簽會更加簡潔,原則上來說,能夠用switch和比較標簽解決的盡量不用if標簽完成。因為switch和比較標簽可以使用變量調節器和系統變量。如果某些特殊的要求下面,IF標簽仍然無法滿足要求的話,可以使用原生php代碼或者PHP標簽來直接書寫代碼。
eq 等於(==)
neq 不等於(!=)
gt 大於(>)
egt 大於等於(>=)
lt 小於(<)
elt 小於等於(<=)
heq 恆等於(===)
nheq 不恆等於(!==)
condition 條件
注意
condition 屬性值中,變量是需要 $ 符號的,這與其他標簽不同。
使用自定義函數的方法
模板變量的函數調用格式:{$varname|function1|function2=arg1,arg2,### }
使用例子:
復制代碼 代碼如下:{$webTitle|md5|strtoupper|substr=0,3}
{$number|number_format=2}
{$varname|function1|function2=arg1,arg2,### }
實例如下:
復制代碼 代碼如下:function Cate($cid){
$Cate=D('Cate');
$Cate=$Cate->where('id='.$cid)->find();
return $Cate['title'];
}
我想在模板中調用這個函數則在模板中可以這樣寫
復制代碼 代碼如下:{$vo.cid|cate=###}
注意:自定義函數要放在項目應用目錄/common/common.php中。 這裡是關鍵。
說明:
{ 和 $ 符號之間不能有空格,後面參數的空格就沒有問題;
###表示模板變量本身的參數位置 ;
支持多個函數,函數之間支持空格 ;
支持函數屏蔽功能,在配置文件中可以配置禁止使用的函數列表 ;
支持變量緩存功能,重復變量字串不多次解析。
更多關於thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《smarty模板入門基礎教程》及《PHP模板技術總結》。
希望本文所述對大家基於ThinkPHP框架的PHP程序設計有所幫助。