What is Smarty?
Why use it?
Use Cases and Work Flow
Syntax Comparison
Template Inheritance
Best Practices
Crash Course
You may use the Smarty logo according to the trademark notice.
                 
                 
              
For sponsorship, advertising, news or other inquiries, contact us at:
Table of Contents
Smarty est fourni en standard avec plusieurs fonctions natives. Ces fonctions natives sont partie intégrante du moteur de Smarty. Vous ne pouvez pas créer de fonctions utilisateurs qui portent le même nom qu'une fonction native et vous ne pouvez pas non plus en modifier le comportement.
  Quelques-unes de ces fonctions ont un attribut
  assign qui récupère le résultat de la
  fonction et la place dans une variable nommée dans le template plutôt que
  de l'afficher ; tout comme la fonction
  {assign}.
 
  {capture} est utilisé pour récupérer la sortie d'éléments dans
  une variable au lieu de les afficher. Tout contenu situé entre
  {capture name='foo'} et {/capture}
  est intercepté dans une variable dont le nom est spécifié dans l'attribut
  name.
 
  Le contenu capturé peut être utilisé dans
  le template par l'intermédiaire de la variable spéciale
  $smarty.capture.foo
  où “foo” est la valeur de l'attribut name.
  Si vous ne donnez pas de valeur à l'attribut name, alors
  “default” est utilisé en tant que nom, i.e.
  $smarty.capture.default.
 
  {capture} peut être imbriqué.
 
| Attribut | Type | Requis | Defaut | Description | 
|---|---|---|---|---|
| name | string | non | default | Le nom du bloc capturé | 
| assign | string | non | n/a | Le nom de la variable à laquelle la sortie sera assignée | 
   Faîtes attention lorsque vous interceptez la sortie de commandes
   {insert}.
   Si vous avez configuré le cache pour que ce
   dernier soit actif, et que vous avez des commandes {insert}
   supposées s'exécuter dans un contenu en cache, ne tentez pas de capturer
   ce contenu.
  
Example 7.1. {capture} avec le nom de l'attribut
{* nous ne voulons afficher une balise div que si le contenu est affiché. *}
{capture name=banner}
  {include file='get_banner.tpl'}
{/capture}
{if $smarty.capture.banner ne ""}
<div id="banner">{$smarty.capture.banner}</div>
{/if}
   
  
Example 7.2. {capture} dans une variable de template
Cet exemple démontre également la fonction
    {popup}
   
{capture name=some_content assign=popText}
Le serveur est {$smarty.server.SERVER_NAME|upper} sur {$smarty.server.SERVER_ADDR}<br>
Votre IP est {$smarty.server.REMOTE_ADDR}.
{/capture}
<a href="#" {popup caption='Information sur le serveur' text=$popText}>Aide</a>
   
 
  Voir aussi
  $smarty.capture,
  {eval},
  {fetch},
  fetch() et
  {assign}.