本文实例讲述了Smarty模板语法。分享给大家供大家参考,具体如下:
所有模版标签用分隔符包围,默认为“{”和“}”。
模板注释
模板注释被星号包围,两边星号被定界符“{ }”包围,如 { smarty * }
smarty注释不会在模板文件的最后输出中出现,这与不同(译注:html注释在页面源码中可见,而smarty注释则不能)。
如下简单代码片{smarty}在源码中不可见,而源码可见。
<html> <head> <tltle>smarty</tltle> <body> {*smarty*} smarty <!--smarty--> </body> </head> </html>
变量初步
模板变量用美元符号开始,可以包含数字、字母和下划线,这php很像。(注意:配置文件变量是一个不用美元符号开始,可以包含数字、字母和下划线,这php很像。(注意:配置文件变量是一个不用美元符号,而是用#号包围着变量(#hashmarks#),或者是一个$smarty.config形式的变量。)
这里config不做说明,下面是变量示例:
{$a+$b} //最简单的变量处理方法 {$a={$b}+1} //标签嵌套标签 {$array[$a]} //变量做数组索引 {$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']} //数组定义 {$fun=stlen($a)} {fun=function($a,$b)} //用作函数参数 {$array.a=1} {$array.a.b.c($array[a][b][c])=1} //数组索引赋值 {$object->method1($x)->method2($y)} //对象链
双引号中插入变量
1、Smarty可以识别嵌入在双引号中的变量,只要此变量只包含数字、字母、下划线和中括号[]。
2、对于句号,数组和对象引用等的符号此变量必须用两个反引号`。
3、Smarty3增加了双引号对Smarty标签的支持。在需要包含调节器变量、插件、php函数返回值的情形中非常实用。
{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} //调节器在引号外 {func var="test {$foo|escape} test"} // 调节器在引号内 {func var="test {time()} test"} // PHP 函数识别 {func var="test {counter} test"} //标签识别
函数
每一个smarty标签输出一个变量或者调用某种函数。在定界符内函数(一般定界符‘{}'包住)和其属性(同样在定界符内)将被处理和输出。例如: {function(函数名) attr1(变量名)=”val”(变量值) attr2=”val”}.