Smarty 到底是什么?
为什么要使用它?
用例和工作流程
语法比较
模板继承
最佳实践
速成课程
{call}
用于调用由 {function}
标签定义的模板函数,就像插件函数一样。
模板函数被定义为全局函数。由于 Smarty 编译器是单趟编译器,{call}
标签必须用于从给定模板外部定义的模板函数中调用模板函数。否则你可以在模板中直接用 {funcname ...}
调用函数。
{call}
标签必须具有 name
属性,其中包含模板函数的名称。
可以使用 属性 将变量值传递给模板函数。
属性
属性名称 | 类型 | 必需 | 默认 | 说明 |
---|---|---|---|---|
name | 字符串 | 是 | 不适用 | 模板函数的名称 |
assign | 字符串 | 否 | 不适用 | 将被调用模板函数的输出分配到的变量名称 |
[var ...] | [var 类型] | 否 | 不适用 | 变量以本地方式传递给模板函数 |
选项标志
名称 | 说明 |
---|---|
nocache | 无缓存模式下调用模板函数 |
示例 7.20 调用递归菜单示例
{* define the function *} {function name=menu level=0} <ul class="level{$level}"> {foreach $data as $entry} {if is_array($entry)} <li>{$entry@key}</li> {call name=menu data=$entry level=$level+1} {else} <li>{$entry}</li> {/if} {/foreach} </ul> {/function} {* create an array to demonstrate *} {$menu = ['item1','item2','item3' => ['item3-1','item3-2','item3-3' => ['item3-3-1','item3-3-2']],'item4']} {* run the array through the function *} {call name=menu data=$menu} {call menu data=$menu} {* short-hand *}
将生成以下输出
* item1 * item2 * item3 o item3-1 o item3-2 o item3-3 + item3-3-1 + item3-3-2 * item4
另请参见 {function}