Smarty 图标

根据 商标注意事项,您可以使用 Smarty 徽标。

Smarty Template Engine Smarty Template Engine

有关赞助、广告、新闻或其他咨询,请联系

使用 Smarty 的网站

广告

{call}

{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}