Manuel Smarty

escape

escape est utilisé pour encoder / échapper une variable pour quelles soient compatibles avec les url html, avec les hexadécimaux, avec les entités hexadécimales, avec javascript et avec les e-mails. Par défaut, ce paramètre est html.

Position du paramètre Type Requis Valeurs possibles Défaut Description
1 chaîne de caractère Non html, htmlall, url, urlpathinfo, quotes, hex, hexentity, javascript, mail html Format d'échappement à utiliser.
2 chaîne de caractère Non ISO-8859-1, UTF-8, ... n'importe quel jeu de caractères supporté par htmlentities() ISO-8859-1 Le jeu de caractères passé à htmlentities()

Exemple 5-10. escape

  1. <?php
  2.  
  3. $smarty->assign('articleTitle', 
  4.          "'Stiff Opposition Expected to Casketless Funeral Plan'" 
  5.          );  
  6. $smarty->assign('EmailAddress','smarty@example.com');  
  7. ?> 

Voici des exemples de template avec escape suivis par l'affichage produit.

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

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

{$articleTitle|escape:'html'}    {* échappe les caractères  & " ' < > *}
'Stiff Opposition Expected to Casketless Funeral Plan'

{$articleTitle|escape:'htmlall'} {* échappe toutes les entités html *}
'Stiff Opposition Expected to Casketless Funeral Plan'

<a href="?title={$articleTitle|escape:'url'}">cliquez-ici</a>
<a href="?title=%27Stiff+Opposition+Expected+to+Casketless+Funeral+Plan%27">cliquez-ici</a>

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

<a href="mailto:{$EmailAddress|escape:"hex"}">{$EmailAddress|escape:"hexentity"}</a>
{$EmailAddress|escape:'mail'}    {* ceci convertit un email en texte *}
<a href="mailto:%62%6f%..snip..%65%74">bob..snip..et</a>

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

Exemple 5-11. Autres exemples

Les fonctions PHP peuvent être utilisées comme modificateurs, suivant la configuration de $security.

{* le paramètre "rewind" enregistre l'emplacement courant *}
<a href="{$SCRIPT_NAME}?page=foo&rewind={$smarty.server.REQUEST_URI|urlencode}">click here</a>

Et ceci est utile pour les e-mails, mais lisez plutôt la documentation de {mailto}

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

Voir aussi la l'anayse Smarty d'échappement, {mailto} et le mascage des adresses e-mail.


Remonter Remonter
L'éditeur javascript - CSS - Gentoo - Tutoriaux PHP - Tutoriels PHP - Bretagne - php - Moto - Kit graphique