aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/smarty/smarty/docs/designers/language-builtin-functions/language-function-function.md
blob: 647e4bfc875db87edec12eff84d78cb68b469e48 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
{function} {#language.function.function}
==========

`{function}` is used to create functions within a template and call them
just like a plugin function. Instead of writing a plugin that generates
presentational content, keeping it in the template is often a more
manageable choice. It also simplifies data traversal, such as deeply
nested menus.

> **Note**
>
> Template functions are defined global. Since the Smarty compiler is a
> single-pass compiler, The [`{call}`](#language.function.call) tag must
> be used to call a template function defined externally from the given
> template. Otherwise you can directly use the function as
> `{funcname ...}` in the template.

-   The `{function}` tag must have the `name` attribute which contains
    the the name of the template function. A tag with this name can be
    used to call the template function.

-   Default values for variables can be passed to the template function
    as [attributes](#language.syntax.attributes). Like in PHP function
    declarations you can only use scalar values as default. The default
    values can be overwritten when the template function is being
    called.

-   You can use all variables from the calling template inside the
    template function. Changes to variables or new created variables
    inside the template function have local scope and are not visible
    inside the calling template after the template function is executed.

**Attributes:**

   Attribute Name       Type       Required   Default  Description
  ---------------- -------------- ---------- --------- ---------------------------------------------------------------
        name           string        Yes       *n/a*   The name of the template function
    \[var \...\]    \[var type\]      No       *n/a*   default variable value to pass local to the template function

> **Note**
>
> You can pass any number of parameter to the template function when it
> is called. The parameter variables must not be declared in the
> `{funcname ...}` tag unless you what to use default values. Default
> values must be scalar and can not be variable. Variables must be
> passed when the template is called.


    {* define the function *}
    {function name=menu level=0}
    {function menu level=0}          {* short-hand *}
      <ul class="level{$level}">
      {foreach $data as $entry}
        {if is_array($entry)}
          <li>{$entry@key}</li>
          {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 *}
    {menu data=$menu}

      

Will generate the following output


    * item1
    * item2
    * item3
          o item3-1
          o item3-2
          o item3-3
                + item3-3-1
                + item3-3-2
    * item4

      

See also [`{call}`](#language.function.call)