Un petit cours pour comprendre le fonctionnement des templates. Cet outil contemporain, clair, puissant et qui offre d'innombrables possibilités.
Que sont les templates ?
Le mot " template " est synonyme de " pattern " en anglais et se traduit en français par " thème ". Comme vous le devinez déjà, les templates servent à modifier l'aspect visuel d'une page (d'un site). Donner le choix d'une interface, est une option de qualité qui fidélisera vos visiteurs les plus réguliers. Par contre, se lancer dans le développement d'un site totalement géré par les templates est un travail de longue haleine et demande beaucoup de temps et de réflexion. A contrario, les templates sont intéressantes lorsque l'on veut séparer le code HTML du code PHP (ou ASP) pour rendre une maintenance et un développement plus facile, par la suite. Par ailleurs, je vous recommande fortement de connaître les classes et les boucles car elles sont omniprésentes dans les codes qui vont suivre. A vos claviers, le cours peut commencer.
Librairie ou classe, que choisir…
Une librairie est un ensemble de fonctions initialisées au démarrage du serveur qui permet une utilisation rapide de celles-ci via le code PHP. Une classe est aussi un ensemble de fonctions mais qui n'est pas initialisé au démarrage du serveur par PHP, mais à l'exécution d'une des fonctions présentes dans la classe. Pour les débutants, il est préférable d'utiliser une classe, car un simple require() ou include() suffit pour pouvoir utiliser les templates (C'est d'ailleurs une classe, que l'on va utiliser dans ce cours). Pour les inconditionnels de l'optimisation de serveur, il est préférable d'utiliser une librairie, car elle est directement exécutée en mode binaire et donc elle est exécutée plus rapidement par le serveur, mais l'insertion d'une librairie en PHP nécessite une bonne connaissance du fichier php.ini et faut-il aussi que votre hébergeur l'ai installé sur son serveur, si vous ne disposez pas de votre propre hébergement. Les classes sont donc conseillées.
Apprentissage par l'exemple
Tout d'abord, télécharger la classe PHPLib que nous allons utiliser pour les exemples. Je vous recommande fortement de l'utiliser car elle est complète et sans erreur.
Une fois téléchargée, placez la dans un dossier quelconque (Ex : template, dans le dossier de votre serveur local) tant que vous enregistrerez les pages exemples dans ce même dossier.
Vous connaissez la fonction, le principe, les modes d'utilisation, vous avez téléchargé et placé la classe dans un dossier ? Alors passons aux exemples. ;)
Bloc simple du genre {VARIABLE}
Les blocs du genre {VARIABLE} sont remplacés par des valeurs et ne peuvent être utilisés qu'une seule fois. Suivez les commentaires pour comprendre le fonctionnement du script.
template_1.tpl
<HTML> <HEAD> <TITLE>Template : Exemple n°1</TITLE> </HEAD> <BODY> <FONT SIZE="1" FACE="Verdana"> Je possède <B>{NBRFRUITS}</B> fruits dans mon panier. </FONT> </BODY> </HTML>
// Création du template $template = new template(".");
// Indication du fichier tpl servant de modèle $template->set_file("template_1","template_1.tpl");
// Calcul du nombre de fruits dans le panier for ($i=0; $i<sizeof($fruits); $i++) { $nbrfruits = $nbrfruits + $panier[$fruits[$i]]; }
// Assignation du bloc simple {NBRFRUITS} par sa valeur $template->set_var("NBRFRUITS", $nbrfruits);
// Traitement de la page entière $template->parse("parse", "template_1");
// Suppression des blocs simples sans valeur ou boucles non utilisés (ici aucun) // Affichage de la page $template->p("parse"); ?>
Bloc boucle du genre <!-- begin/end boucle -->
Les blocs du genre <!-- BEGIN BOUCLE --> et <!-- END BOUCLE --> sont répétés autant de fois qu'on le désire. Ils sont utilisés comme des balises HTML. On remplace les blocs simple du genre {VARIABLE} situés à l'intérieur, à chaque utilisation de ces blocs. Suivez les commentaires pour comprendre le fonctionnement du script.
template_2.tpl
<HTML> <HEAD> <TITLE>Template : Exemple n°2</TITLE> </HEAD> <BODY> <FONT SIZE="1" FACE="Verdana"> Je possède <B>{NBRFRUITS}</B> fruits dans mon panier.<BR><BR> <B>Détails du contenu de mon panier</B><BR> <!-- BEGIN DETAILS --> <U>Fruit</U> : {FRUIT}<BR> <U>Quantité</U> : {NBR}<BR><BR> <!-- END DETAILS --> </FONT> </BODY> </HTML>
// Création du template $template = new template(".");
// Indication du fichier tpl servant de modèle $template->set_file("template_2","template_2.tpl");
// Calcul du nombre de fruits dans le panier for ($i=0; $i<sizeof($fruits); $i++) { $nbrfruits = $nbrfruits + $panier[$fruits[$i]]; }
// Assignation du bloc simple {NBRFRUITS} par sa valeur $template->set_var("NBRFRUITS", $nbrfruits);
// Déclaration du bloc boucle DETAILS $template->set_block("template_2","DETAILS","details");
// Traitement de mon panier for ($i=0; $i<sizeof($fruits); $i++) { // Assignation des blocs simple {FRUIT} et {NBR} par leur valeur $template->set_var("FRUIT",$fruits[$i]); $template->set_var("NBR",$panier[$fruits[$i]]); // Remplacement des blocs simples {FRUIT} et {NBR} utilisés par leur valeur dans le bloc boucle DETAILS $template->parse("details", "DETAILS", true); }
// Traitement de la page entière $template->parse("parse", "template_2", true);
// Suppression des blocs simples sans valeur ou boucles non utilisés (ici aucun) // Affichage de la page $template->p("parse"); ?>
Avec ceci, vous avez de quoi vous occuper pendant un bon moment !