IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Initiation aux templates en PHP avec Smarty


précédentsommairesuivant

IV. Les fonctions natives

La compréhension des fonctions Smarty est indispensable, en effet c'est grâce aux fonctions que vous allez pouvoir répéter une portion de code, insérer du code en fonction de certaines conditions, insérer du javascript dans vos templates et bien d'autres choses encore.

Les fonctions s'utilisent entre accolades ex. : {section}. Comme en html avec les balises, toute déclaration de fonction s'accompagne d'une balise de « fermeture ». Pour la fonction {section} on utilisera par exemple {/section}.

IV-A. Section

Cette fonction essentielle est peut-être la première qui m'a fait prendre conscience du potentiel de Smarty.

Section vous permet d'afficher une portion de code HTML autant de fois qu'il y a d'éléments dans le conteneur qui lui a été indiqué. C'est en fait strictement la même chose qu'une boucle, gardez toujours ça à l'esprit. Pour que tout cela fonctionne, il faut donc avoir passé à Smarty un conteneur de données (tableau ou objet) et lui se charge du reste.

Vous devez spécifier au moins deux arguments : LOOP qui est la variable Smarty (tableau ou objet assigné en PHP) et un attribut NAME dont la valeur représente le nom de la SECTION. La valeur de NAME est comme un index que nous utiliserons dans la fonction pour accéder à l'élément courant, aller un exempleš:

section.php
Sélectionnez
// Inclure la bibliothèque smarty
require_once('../smarty/Smarty.class.php');
 
// Instancier l'objet smarty
$oSmarty = new Smarty();
 
$aMonTableau = array("Jean", "Jean-Luc", "Sylvain", "Eric");
 
// 2. Recensement dans smarty de la variable $aMonTableau
$oSmarty->assign('smarty_tableau', $aMonTableau);
 
// 3. Affichage du template après passage de l'objet
$oSmarty->display('section.tpl');

Jusqu'ici, rien de particulier, la nouveauté se trouve dans le template :

section.tpl
Sélectionnez
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
 <html>
    <head>
        <title>La fonction section</title>
    </head>
    <body>
        <h2>La fonction section</h2>
        <ul>
            <!--Bloc répété autant de fois qu'il y aura d'éléments dans '$smarty_tableau'-->
            {section name=idx_smarty_tableau loop=$smarty_tableau}
                <li>{$smarty_tableau[idx_smarty_tableau]}</li>
            {/section}
        </ul>      
    </body>
</html>
Section

IV-B. If, else, elseif

Tout comme en PHP, Smarty offre dans ses templates la possibilité d'afficher du contenu en fonction de certaines conditions définies par le développeur (ou le graphiste) dans le fichier de template. Prenons l'exemple de la gestion d'un profil « administrateur » où certains éléments ne doivent pas être affichés dans certains cas. On pourra tester l'existence ou la valeur d'une variable pour déterminer que la portion de code concernée doit ou ne doit pas s'afficher.

On déclarera la fonction « IF » de cette façon {if ma_condition}mon code…{/if}. Dans le cas du {IF}, l'argument (ma_condition) est la condition que l'on souhaite évaluer (égalité, différence, négation…). Un exemple :

if.php
Sélectionnez
// Inclure la bibliothèque smarty
require_once('../smarty/Smarty.class.php');
 
// Instancier notre objet smarty
$oSmarty = new Smarty();
 
$userIsAdmin = 'true';
 
// 2. Recensement dans smarty
$oSmarty->assign('smarty_userIsAdmin', $userIsAdmin);
 
// 3. Affichage du template après passage de l'objet
$oSmarty->display('if.tpl');

Ici encore rien de particulier côté PHP, c'est la partie TEMPLATE qui est concernée, dans cet exemple, on teste la valeur d'une variable Smarty concernant les droits d'un utilisateur.

if.tpl
Sélectionnez
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
 <html>
    <head>
        <title>Fonctions IF/ELSE/ELSEIF</title>
    </head>
    <body>
        <h2>Les fonctions IF/ELSE/ELSEIF</h2>
 
        {if $smarty_userIsAdmin == 'true'}
            <div>Salut administrateur</div>
        {else}
            <div>Salut utilisateur lambda !!</div>
        {/if}
 
    </body>
</html>

IV-C. Literal

Literal vous permet de désactiver un temps l'interprétation Smarty. Cela permet notamment l'insertion de scripts JAVASCRIPT qui générèrent habituellement des erreurs (entre autres à cause des accolades).

En effet le fichier de templates suivant génère une erreur :

sansLiteral.tpl
Sélectionnez
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
 <html>
    <head>
    <title></title>
    </head>
    <body>
        <script language="JavaScript" type="text/javascript">
            function test () {
                alert('Bonjour le monde !!');
            }
        </script>
    </body>
</html>

Fatal error: Smarty error: [in index.tpl line 10]: syntax error: unrecognized tag: alert('Bonjour le monde !!'); (Smarty_Compiler.class.php, line 439) in C:\Program Files\wamp\www\demos\smarty\lib_smarty\Smarty.class.php on line 1095

En utilisant la fonction {LITERAL}, c'est-à-dire en entourant le script javascript ou la C.S.S. concernés, cela ne posera plus de problème :

avecLiteral.tpl
Sélectionnez
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <title>Literal</title>
    </head>
<body>
    {LITERAL}
    <script language="JavaScript" type="text/javascript">
        function test () {
        alert('Bonjour le monde !!');
    }
    </script>
    {/LITERAL}
</body>
</html>

IV-D. Include

Cette fonction permet d'appeler dans un template un autre template, dans la même idée qu'un include() PHP. Cela permet de découpler encore plus la présentation. Nous allons voir dans l'exemple suivant le cas d'une zone principale et d'un « HEADER ».

include.php
Sélectionnez
require_once('../smarty/Smarty.class.php');
 
// Instancier l'objet smarty
$oSmarty = new Smarty();
 
$oSmarty->assign('header_text', "Ceci est l'entête de ma page !!!");
$oSmarty->assign('main_text', "Ceci est la zone principale de ma page !!!");
 
// 3. Affichage du template après passage de l'objet
$oSmarty->display('include.tpl');

Le fichier de template que l'on va inclure :

header.tpl
Sélectionnez
<div id="header" style="background-color:teal;">
    <h1>{$header_text}</h1>
</div>

Voyons maintenant le template qui prend en charge l'inclusion (ici du template header.tpl)

include.tpl
Sélectionnez
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
 "http://www.w3.org/TR/html4/loose.dtd">
 <html>
    <head>
        <title>Exemple d'include</title>
    </head>
    <body>
        {include file="header.tpl"}
        <div id="main" style="background-color:#6699cc;">
            <h1>{$main_text}</h1>
        </div>
    </body>
</html>
Image non disponible

Dans le template inclus, on peut utiliser sans problème les variables Smarty.


précédentsommairesuivant

Copyright © 2008 Eric POMMEREAU. Aucune reproduction, même partielle, ne peut être faite de ce site ni de l'ensemble de son contenu : textes, documents, images, etc. sans l'autorisation expresse de l'auteur. Sinon vous encourez selon la loi jusqu'à trois ans de prison et jusqu'à 300 000 € de dommages et intérêts.