Smarty模板語法詳解
本文實例講述了Smarty模板語法。分享給大家供大家參考,具體如下:
所有模版標簽用分隔符包圍,默認為“{”和“}”。
模板注釋
模板注釋被星號包圍,兩邊星號被定界符“{ }”包圍,如 { smarty * }
smarty注釋不會在模板文件的最后輸出中出現(xiàn),這與不同(譯注:html注釋在頁面源碼中可見,而smarty注釋則不能)。
如下簡單代碼片{smarty}在源碼中不可見,而源碼可見。
<html> <head> <tltle>smarty</tltle> <body> {*smarty*} smarty <!--smarty--> </body> </head> </html>
變量初步
模板變量用美元符號開始,可以包含數(shù)字、字母和下劃線,這php很像。(注意:配置文件變量是一個不用美元符號開始,可以包含數(shù)字、字母和下劃線,這php很像。(注意:配置文件變量是一個不用美元符號,而是用#號包圍著變量(#hashmarks#),或者是一個$smarty.config形式的變量。)
這里config不做說明,下面是變量示例:
{$a+$b} //最簡單的變量處理方法 {$a={$b}+1} //標簽嵌套標簽 {$array[$a]} //變量做數(shù)組索引 {$assign var=fun value=$a+$b} //變量賦值 {$fun="{a}"} //引號套用標簽 {$assign var=fun value=[1,2,3]} {$assign var=fun value=[1,2,[3,4]]} {$assign var=fun value=[1=>'one',2=>'tow']} //數(shù)組定義 {$fun=stlen($a)} {fun=function($a,$b)} //用作函數(shù)參數(shù) {$array.a=1} {$array.a.b.c($array[a][b][c])=1} //數(shù)組索引賦值 {$object->method1($x)->method2($y)} //對象鏈
雙引號中插入變量
1、Smarty可以識別嵌入在雙引號中的變量,只要此變量只包含數(shù)字、字母、下劃線和中括號[]。
2、對于句號,數(shù)組和對象引用等的符號此變量必須用兩個反引號`。
3、Smarty3增加了雙引號對Smarty標簽的支持。在需要包含調(diào)節(jié)器變量、插件、php函數(shù)返回值的情形中非常實用。
{function var="test $foo test"} // 識別 $foo {func var="test $foo_bar test"} // 識別 $foo_bar {func var="test `$foo[0]` test"} // 識別 $foo[0] {func var="test `$foo[bar]` test"} // 識別 $foo[bar] {func var="test $foo.bar test"} // 識別 $foo (無法識別 $foo.bar) {func var="test `$foo.bar` test"} // 識別 $foo.bar {func var="test `$foo.bar` test"|escape} //調(diào)節(jié)器在引號外 {func var="test {$foo|escape} test"} // 調(diào)節(jié)器在引號內(nèi) {func var="test {time()} test"} // PHP 函數(shù)識別 {func var="test {counter} test"} //標簽識別
函數(shù)
每一個smarty標簽輸出一個變量或者調(diào)用某種函數(shù)。在定界符內(nèi)函數(shù)(一般定界符‘{}'包?。┖推鋵傩裕ㄍ瑯釉诙ń绶麅?nèi))將被處理和輸出。例如: {function(函數(shù)名) attr1(變量名)=”val”(變量值) attr2=”val”}.
{config_load file="colors.conf"} {include file="header.tpl"} {if $highlight_name} Welcome, <font color="{#fontColor#}">{$name}!</font> {else} Welcome, {$name}! {/if} {include file="footer.tpl"}
1、在模板里無論是內(nèi)置函數(shù)還是自定義函數(shù)都有相同的語法。
2、內(nèi)置函數(shù)將在smarty內(nèi)部工作,例如{if}、{section}和{strip},不能修改他們。
3、自定義函數(shù)通過插件機制起作用,它們是附加函數(shù)。只要你喜歡,可以隨意修改,你也可以自行添加。例如{html_options}和{html_select_date}。
屬性
大多數(shù)函數(shù)都帶有自己的屬性以便于明確說明或者修改他們的行為,smarty函數(shù)的屬性很像HTML中的屬性。靜態(tài)數(shù)值不需要加引號,但是字符串建議使用引號。可以使用普通smarty變量,也可以使用帶調(diào)節(jié)器的變量作為屬性值,它們也不用加引號。你甚至可以使用php函數(shù)返回值和復(fù)雜表達式作為屬性值。
Math
數(shù)學(xué)運算可以直接作用到變量值。
{$foo+1} {$foo*$bar} {$foo|truncate:"`$fooTruncCount/$barTruncFactor-1`"} {assign var="foo" value="`$foo+$bar`"}
忽略smarty語法
忽略Smarty對某些語句段的解析很有必要。一種典型的情況是嵌入到模板中的javascript或Css代碼。原因在于這些語言使用與Smarty默認定界符‘{'和‘}'一樣的符號。
方法:一個避免出現(xiàn)這種情況的好習(xí)慣是把你的javascript/css代碼分離出來保存成一個獨立文件,再用html方法鏈接到模版中。這樣做也有利于瀏覽器緩存腳本。如果你想把Smarty變量、方法嵌入到j(luò)avascript/css,請看下面的運用。
在Smarty模版,如果‘{'和‘}'大括號里包含有空格那么整個{}內(nèi)容會被忽略,你可以設(shè)置Smarty類變量$auto_literal=false來取消這種規(guī)則。
<script> // the following braces are ignored by Smarty 以下大括號的內(nèi)容會被Smarty忽略 // since they are surrounded by whitespace 因為它們里面有空格 function foobar { alert('foobar!'); } // this one will need literal escapement 下面的內(nèi)容會保持原義輸出 {literal} function bazzy {alert('foobar!');} {/literal} </script>
{literal}…{/literal}
塊被用來忽略模版語法的解析,你也可以用{idelim}
,{rdelim}
標簽或{smarty.Idelim}
、{smarty.Idelim}
、{smarty.rdelim}
變量來忽略個別大括號(譯注:后面兩種方法主要用來在模版中輸出左右大括號)。
更多關(guān)于Smarty相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《smarty模板入門基礎(chǔ)教程》、《PHP模板技術(shù)總結(jié)》、《PHP基于pdo操作數(shù)據(jù)庫技巧總結(jié)》、《PHP運算與運算符用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于smarty模板的PHP程序設(shè)計有所幫助。
相關(guān)文章
PHP設(shè)計模式(九)外觀模式Facade實例詳解【結(jié)構(gòu)型】
這篇文章主要介紹了PHP設(shè)計模式:外觀模式Facade,結(jié)合實例形式詳細分析了PHP外觀模式Facade相關(guān)概念、功能、原理、用法與操作注意事項,需要的朋友可以參考下2020-05-05web server使用php生成web頁面的三種方法總結(jié)
web server使用php生成web頁面的三種方法。需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10