aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/smarty/smarty/docs/designers/language-modifiers/language-modifier-escape.md
blob: 37c71dde9c619072d928122d95e40b4e54fe54ae (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
escape {#language.modifier.escape}
======

`escape` is used to encode or escape a variable to `html`, `url`,
`single quotes`, `hex`, `hexentity`, `javascript` and `mail`. By default
its `html`.

   Parameter Position    Type     Required                                                Possible Values                                                 Default  Description
  -------------------- --------- ---------- ------------------------------------------------------------------------------------------------------------ --------- -------------------------------------------------------------------------------------
           1            string       No             `html`, `htmlall`, `url`, `urlpathinfo`, `quotes`, `hex`, `hexentity`, `javascript`, `mail`           `html`   This is the escape format to use.
           2            string       No      `ISO-8859-1`, `UTF-8`, and any character set supported by [`htmlentities()`](&url.php-manual;htmlentities)   `UTF-8`  The character set encoding passed to htmlentities() et. al.
           3            boolean      No                                                        FALSE                                                       TRUE    Double encode entites from & to & (applys to `html` and `htmlall` only)


    <?php

    $smarty->assign('articleTitle',
                    "'Stiff Opposition Expected to Casketless Funeral Plan'"
                    );
    $smarty->assign('EmailAddress','smarty@example.com');

    ?>

       

These are example `escape` template lines followed by the output


    {$articleTitle}
    'Stiff Opposition Expected to Casketless Funeral Plan'

    {$articleTitle|escape}
    &#039;Stiff Opposition Expected to Casketless Funeral Plan&#039;

    {$articleTitle|escape:'html'}    {* escapes  & " ' < > *}
    &#039;Stiff Opposition Expected to Casketless Funeral Plan&#039;

    {$articleTitle|escape:'htmlall'} {* escapes ALL html entities *}
    &#039;Stiff Opposition Expected to Casketless Funeral Plan&#039;

    <a href="?title={$articleTitle|escape:'url'}">click here</a>
    <a
    href="?title=%27Stiff%20Opposition%20Expected%20to%20Casketless%20Funeral%20Plan%27">click here</a>

    {$articleTitle|escape:'quotes'}
    \'Stiff Opposition Expected to Casketless Funeral Plan\'

    <a href="mailto:{$EmailAddress|escape:"hex"}">{$EmailAddress|escape:"hexentity"}</a>
    {$EmailAddress|escape:'mail'}    {* this converts to email to text *}
    <a href="mailto:%62%6f%..snip..%65%74">&#x62;&#x6f;&#x62..snip..&#x65;&#x74;</a>

    {'mail@example.com'|escape:'mail'}
    smarty [AT] example [DOT] com

       


    {* the "rewind" parameter registers the current location *}
    <a href="$my_path?page=foo&rewind=$my_uri|urlencode}">click here</a>

       

This snippet is useful for emails, but see also
[`{mailto}`](#language.function.mailto)


    {* email address mangled *}
    <a href="mailto:{$EmailAddress|escape:'hex'}">{$EmailAddress|escape:'mail'}</a>

       

See also [escaping smarty parsing](#language.escaping),
[`{mailto}`](#language.function.mailto) and the [obfuscating email
addresses](#tips.obfuscating.email) page.