recherche
Maisondéveloppement back-endtutoriel phpTwig - Le moteur de modèle PHP autonome le plus populaire

Twig - the Most Popular Stand-Alone PHP Template Engine

Twig: un moteur de modèle PHP populaire

Twig est un moteur de modèle PHP populaire développé par Sensio Labs. Twig agit à la fois sur le frontend et le backend du projet, et peut être vu de deux perspectives: des brindilles pour les concepteurs de modèles et des brindilles pour les développeurs. Twig utilise un objet central nommé Environment pour stocker des configurations, des extensions et des modèles de chargement à partir d'un système de fichiers ou ailleurs. Twig prend en charge les modèles imbriqués (blocs), en évitant la duplication des éléments dans les modèles, et peut mettre en cache des modèles compilés pour accélérer les demandes ultérieures. Twig prend en charge les instructions, boucles et filtres conditionnels pour contrôler l'affichage des informations dans les modèles et fournit des capacités de débogage pour vider toutes les informations sur les variables de modèle.

Cet article a été évalué par des pairs par Wern Ancheta. Merci à tous les pairs examinateurs de SitePoint pour avoir obtenu le contenu de SitePoint à son meilleur!


Twig est le moteur de modèle de PHP. Mais PHP est-il lui-même un moteur de modèle? Oui, pas! Bien que PHP ait été à l'origine utilisé comme moteur de modèle, il ne s'est pas développé, et bien que nous puissions toujours l'utiliser comme moteur de modèle, quelle version de "Hello World" préférez-vous:

<?php echo "<p> Hello " . $name . "</p>"; ?>

ou

<p>Hello {{ name }}</p>

PHP est un langage verbeux qui est amplifié lorsque vous essayez de sortir du contenu HTML. Les systèmes de modèles modernes élimineront la verbance partielle et y ajouteront pas mal de fonctionnalités. Des fonctionnalités telles que les capacités de sécurité et de débogage sont l'épine dorsale des moteurs de modèles modernes. Aujourd'hui, nous nous concentrerons sur les brindilles.

Twig - the Most Popular Stand-Alone PHP Template Engine

Twig est un moteur de modèle créé par Sensio Labs (la société de développement de Blackfire et Symfony). Jetons un coup d'œil à ses principaux avantages et comment l'utiliser dans votre projet.

Installation

Il existe deux façons d'installer des brindilles. Nous pouvons utiliser les packages de goudron disponibles sur leur site Web ou utiliser le compositeur comme nous l'avons fait.

composer require twig/twig

Nous supposons que vous exécutez un environnement où PHP est configuré et le compositeur est installé à l'échelle mondiale. La meilleure façon est d'utiliser l'amélioration de Homestead - il vous permet de commencer à l'utiliser en 5 minutes sur exactement la même machine que nous utilisons afin que nous puissions être sur la même longueur d'onde. Si vous voulez en savoir plus sur l'environnement PHP, nous avons un excellent livre rémunéré à ce sujet ici pour l'achat.

Nous devons clarifier quelque chose avant de pouvoir continuer. En tant que moteur de modèle, Twig agit à la fois sur le frontend et le backend du projet. Nous pouvons donc regarder des brindilles sous deux perspectives différentes: des brindilles pour les concepteurs de modèles et des brindilles pour les développeurs. D'une part, nous préparons toutes les données dont nous avons besoin;

Utilisation de base

Pour illustrer l'utilisation de base de Twig, créons un projet simple. Tout d'abord, nous devons amorcer des brindilles. Créons un fichier bootstrap.php avec le contenu suivant:

<?php echo "<p> Hello " . $name . "</p>"; ?>

Twig utilise un objet central nommé Environment. Les instances de ce type sont utilisées pour stocker des configurations, des extensions et des modèles de chargement à partir de systèmes de fichiers ou d'autres emplacements. Après nos bottes d'instance de brina, nous pouvons aller de l'avant et créer un fichier index.php où il charge certaines données et les transmet au modèle de brindilles.

<p>Hello {{ name }}</p>

Il s'agit d'un exemple simple; nous créons un tableau contenant des produits, tels que notre clavier mécanique, que nous pouvons utiliser dans les modèles. Ensuite, nous utilisons la méthode render(), qui accepte le nom du modèle (il s'agit d'un fichier dans le dossier de modèle que nous avons défini précédemment) et les données que nous voulons transmettre au modèle. Pour terminer notre exemple, allons dans notre dossier /templates et créons un fichier index.html. Tout d'abord, regardons le modèle lui-même.

composer require twig/twig

ouvrir index.php dans votre navigateur (visitez localhost ou homestead.app, selon la façon dont vous configurez l'hôte et le serveur) devrait maintenant afficher l'écran suivant:

Twig - the Most Popular Stand-Alone PHP Template Engine

Mais revenons et examinons de plus près notre code de modèle. Il existe deux types de séparateurs: {{ ... }} est utilisé pour imprimer les résultats d'une expression ou d'une opération, tandis que {% ... %} est utilisé pour exécuter des instructions telles que les instructions conditionnelles et les boucles. Ces délimiteurs sont la principale structure linguistique de Twig, que Twig utilise pour "informer" le modèle qu'il doit rendre l'élément brindille.

(Le contenu suivant est similaire au texte d'origine, mais certains ajustements de déclaration et des divisions de paragraphe ont été effectués, et la position de l'image reste inchangée)

Layout

Pour éviter la duplication des éléments (tels que les en-têtes et les pieds de pied) dans les modèles, les brindilles nous permettent de nicher de modèles dans des modèles, qui sont appelés blocs. Pour illustrer cela, séparons le contenu réel de la définition HTML dans l'exemple. Créons un nouveau fichier HTML et nommez-le layout.html:

<?php
// 加载我们的自动加载器
require_once __DIR__.'/vendor/autoload.php';

// 指定我们的Twig模板位置
$loader = new Twig_Loader_Filesystem(__DIR__.'/templates');

// 实例化我们的Twig
$twig = new Twig_Environment($loader);

Nous avons créé un bloc appelé content. Nous entendons que chaque modèle s'étendant de layout.html peut implémenter un bloc content, qui sera affiché à cet endroit. De cette façon, nous pouvons réutiliser la disposition plusieurs fois sans la réécrire. Dans ce cas, le fichier index.html ressemble maintenant à ceci:

<?php
require_once __DIR__.'/bootstrap.php';

// 创建产品列表
$products = [
    [
        'name'          => 'Notebook',
        'description'   => 'Core i7',
        'value'         =>  800.00,
        'date_register' => '2017-06-22',
    ],
    [
        'name'          => 'Mouse',
        'description'   => 'Razer',
        'value'         =>  125.00,
        'date_register' => '2017-10-25',
    ],
    [
        'name'          => 'Keyboard',
        'description'   => 'Mechanical Keyboard',
        'value'         =>  250.00,
        'date_register' => '2017-06-23',
    ],
];

// 渲染我们的视图
echo $twig->render('index.html', ['products' => $products] );

Twig nous permet également de ne rendre que des blocs uniques. Pour ce faire, nous devons d'abord charger le modèle, puis rendre le bloc.

<!DOCTYPE html>
<html lang="pt-BR">
    <head>
        <meta charset="UTF-8">
        <title>Twig Example</title>
    </head>
    <body>
    <table> border="1" style="width: 80%;">
        <thead>
            <tr>
                <td>Product</td>
                <td>Description</td>
                <td>Value</td>
                <td>Date</td>
            </tr>
        </thead>
        <tbody>
            {% for product in products %}
                <tr>
                    <td>{{ product.name }}</td>
                    <td>{{ product.description }}</td>
                    <td>{{ product.value }}</td>
                    <td>{{ product.date_register|date("m/d/Y") }}</td>
                </tr>
            {% endfor %}
        </tbody>
    </table>
    </body>
</html>

À ce stade, nous avons toujours la même page, mais nous réduisons sa complexité en découplant les blocs de contexte.

cache

Environment Les objets peuvent non seulement être utilisés pour charger des modèles. Si nous passons en utilisant l'option cache du répertoire associé, Twig mettra en cache le modèle compilé, évitant ainsi d'analyser le modèle dans les demandes suivantes. Le modèle compilé sera stocké dans le répertoire que nous fournissons. Notez qu'il s'agit du cache des modèles compilés, pas du cache pour les modèles évalués. Cela signifie que Twig analyse, compile et enregistrera le fichier de modèle. Toutes les demandes suivantes nécessitent toujours des modèles d'évaluation, mais la première étape est déjà effectuée pour vous. Cachetons le modèle dans l'exemple en modifiant le fichier bootstrap.php:

<?php echo "<p> Hello " . $name . "</p>"; ?>

(Le contenu suivant est similaire au texte d'origine, mais certains ajustements de déclaration et des divisions de paragraphe ont été effectués, et la position de l'image reste inchangée)

cycle

Dans notre exemple, nous avons vu comment boucler avec des brindilles. Fondamentalement, nous utilisons la balise for et attribuons un alias à chaque élément du tableau spécifié. Dans ce cas, nous attribuons un alias au tableau products. Après cela, nous pouvons utiliser l'opérateur product pour accéder à toutes les propriétés de chaque élément de tableau. Nous utilisons la balise . pour indiquer l'extrémité de la boucle. Nous pouvons également parcourir les chiffres ou les lettres à l'aide de l'opérateur endfor. Comme indiqué ci-dessous: ..

<p>Hello {{ name }}</p>
ou lettre:

composer require twig/twig
Cet opérateur n'est que le sucre de syntaxe de la fonction

, et il fonctionne de la même manière que la fonction PHP range native. Une option tout aussi utile consiste à ajouter des conditions à la boucle. En utilisant des conditions, nous pouvons filtrer les éléments pour itérer. Supposons que nous voulons itérer tous les produits avec une valeur inférieure à 250: range

<?php
// 加载我们的自动加载器
require_once __DIR__.'/vendor/autoload.php';

// 指定我们的Twig模板位置
$loader = new Twig_Loader_Filesystem(__DIR__.'/templates');

// 实例化我们的Twig
$twig = new Twig_Environment($loader);

Énoncé conditionnel

Twig fournit également des instructions conditionnelles sous la forme de balises

, if, elseif et if not. Tout comme dans n'importe quel langage de programmation, nous pouvons utiliser ces balises pour filtrer les conditions dans les modèles. Supposons que dans notre exemple, nous voulons afficher uniquement des produits avec une valeur supérieure à 500: else

<?php
require_once __DIR__.'/bootstrap.php';

// 创建产品列表
$products = [
    [
        'name'          => 'Notebook',
        'description'   => 'Core i7',
        'value'         =>  800.00,
        'date_register' => '2017-06-22',
    ],
    [
        'name'          => 'Mouse',
        'description'   => 'Razer',
        'value'         =>  125.00,
        'date_register' => '2017-10-25',
    ],
    [
        'name'          => 'Keyboard',
        'description'   => 'Mechanical Keyboard',
        'value'         =>  250.00,
        'date_register' => '2017-06-23',
    ],
];

// 渲染我们的视图
echo $twig->render('index.html', ['products' => $products] );

Filtre

Les filtres nous permettent de filtrer les informations transmises au modèle et au format des informations affichées. Jetons un coup d'œil à certains des filtres les plus couramment utilisés et importants. Une liste complète des filtres à brinations peut être trouvée ici.

Date et

date_modify

Filtre Formats à la date du format donné. Comme nous le voyons dans l'exemple: date

<!DOCTYPE html>
<html lang="pt-BR">
    <head>
        <meta charset="UTF-8">
        <title>Twig Example</title>
    </head>
    <body>
    <table> border="1" style="width: 80%;">
        <thead>
            <tr>
                <td>Product</td>
                <td>Description</td>
                <td>Value</td>
                <td>Date</td>
            </tr>
        </thead>
        <tbody>
            {% for product in products %}
                <tr>
                    <td>{{ product.name }}</td>
                    <td>{{ product.description }}</td>
                    <td>{{ product.value }}</td>
                    <td>{{ product.date_register|date("m/d/Y") }}</td>
                </tr>
            {% endfor %}
        </tbody>
    </table>
    </body>
</html>
Nous affichons les dates au format mois / jour / an. En plus du filtre

, nous pouvons également utiliser le filtre date pour modifier la date à l'aide du filtre date_modify. Par exemple, si nous voulons ajouter une journée à une date, nous pouvons utiliser ce qui suit:

<!DOCTYPE html>
<html lang="pt-BR">
    <head>
        <meta charset="UTF-8">
        <title>Tutorial Example</title>
    </head>
    <body>
        {% block content %}
        {% endblock %}
    </body>
</html>

format

Format la chaîne donnée en remplaçant tous les espaces réservés. Par exemple:

{% extends "layout.html" %}

{% block content %}
    <table> border="1" style="width: 80%;">
        <thead>
            <tr>
                <td>Product</td>
                <td>Description</td>
                <td>Value</td>
                <td>Date</td>
            </tr>
        </thead>
        <tbody>
            {% for product in products %}
                <tr>
                    <td>{{ product.name }}</td>
                    <td>{{ product.description }}</td>
                    <td>{{ product.value }}</td>
                    <td>{{ product.date_register|date("m/d/Y") }}</td>
                </tr>
            {% endfor %}
        </tbody>
    </table>
{% endblock %}

striptags

striptags Le filtre supprime les balises SGML / XML et remplace les espaces adjacents avec des espaces:

<?php echo "<p> Hello " . $name . "</p>"; ?>

escape

escape est l'un des filtres les plus importants. Il filtre la chaîne à insérer en toute sécurité dans la sortie finale. Par défaut, il utilise la stratégie d'échappement HTML, donc

<p>Hello {{ name }}</p>

équivalent à

composer require twig/twig

js, css, url, html_attr et

Les politiques d'échappement sont également disponibles. Ce sont respectivement JavaScript, CSS, URI et HTML, les chaînes d'échappement du contexte d'attribut.

DEBUG

dump() Enfin, jetons un coup d'œil au débogage. Parfois, nous devons accéder à toutes les informations de la variable de modèle. Pour ce faire, Twig a une fonction Twig_Extension_Debug. Cette fonction n'est pas disponible par défaut. Lors de la création d'un environnement de brindilles, nous devons ajouter l'extension

:
<?php
// 加载我们的自动加载器
require_once __DIR__.'/vendor/autoload.php';

// 指定我们的Twig模板位置
$loader = new Twig_Loader_Filesystem(__DIR__.'/templates');

// 实例化我们的Twig
$twig = new Twig_Environment($loader);

dump() Cette étape est nécessaire afin que nous ne divulguons pas accidentellement des informations de débogage sur le serveur de production. Une fois la configuration terminée, nous utilisons simplement la fonction

pour vider toutes les informations sur les variables de modèle.
<?php
require_once __DIR__.'/bootstrap.php';

// 创建产品列表
$products = [
    [
        'name'          => 'Notebook',
        'description'   => 'Core i7',
        'value'         =>  800.00,
        'date_register' => '2017-06-22',
    ],
    [
        'name'          => 'Mouse',
        'description'   => 'Razer',
        'value'         =>  125.00,
        'date_register' => '2017-10-25',
    ],
    [
        'name'          => 'Keyboard',
        'description'   => 'Mechanical Keyboard',
        'value'         =>  250.00,
        'date_register' => '2017-06-23',
    ],
];

// 渲染我们的视图
echo $twig->render('index.html', ['products' => $products] );

Conclusion

J'espère que cet article vous fournira une base solide pour les bases de brindilles et commencera immédiatement votre projet! Si vous voulez avoir un aperçu plus approfondi de Twig, le site officiel fournit une très bonne documentation et des références que vous pouvez consulter. Utilisez-vous le moteur de modèle? Que pensez-vous de Twig? Souhaitez-vous le comparer à des alternatives populaires comme Blade ou Smarty?

(Le contenu suivant est la FAQ, le texte d'origine a été inclus, omis ici)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
PHP en action: Exemples et applications du monde réelPHP en action: Exemples et applications du monde réelApr 14, 2025 am 12:19 AM

PHP est largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et le développement d'API. 1) E-commerce: Utilisé pour la fonction de panier et le traitement des paiements. 2) Système de gestion du contenu: utilisé pour la génération de contenu dynamique et la gestion des utilisateurs. 3) Développement des API: Utilisé pour le développement de l'API RESTful et la sécurité de l'API. Grâce à l'optimisation des performances et aux meilleures pratiques, l'efficacité et la maintenabilité des applications PHP sont améliorées.

PHP: Création de contenu Web interactif avec facilitéPHP: Création de contenu Web interactif avec facilitéApr 14, 2025 am 12:15 AM

PHP facilite la création de contenu Web interactif. 1) Générez dynamiquement du contenu en intégrant HTML et affichez-les en temps réel en fonction des données d'entrée ou de base de données utilisateur. 2) Traitez la soumission du formulaire et générez une sortie dynamique pour garantir que HTMLSpecialChars est utilisé pour empêcher les XS. 3) Utilisez MySQL pour créer un système d'enregistrement des utilisateurs, et utilisez des instructions Password_hash et du prétraitement pour améliorer la sécurité. La maîtrise de ces techniques améliorera l'efficacité du développement Web.

PHP et Python: comparaison de deux langages de programmation populairesPHP et Python: comparaison de deux langages de programmation populairesApr 14, 2025 am 12:13 AM

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

La pertinence durable de PHP: est-elle toujours vivante?La pertinence durable de PHP: est-elle toujours vivante?Apr 14, 2025 am 12:12 AM

PHP est toujours dynamique et occupe toujours une position importante dans le domaine de la programmation moderne. 1) La simplicité de PHP et le soutien communautaire puissant le rendent largement utilisé dans le développement Web; 2) sa flexibilité et sa stabilité le rendent exceptionnelle dans la gestion des formulaires Web, des opérations de base de données et du traitement de fichiers; 3) PHP évolue et optimise constamment, adapté aux débutants et aux développeurs expérimentés.

Statut actuel de PHP: un regard sur les tendances de développement WebStatut actuel de PHP: un regard sur les tendances de développement WebApr 13, 2025 am 12:20 AM

Le PHP reste important dans le développement Web moderne, en particulier dans la gestion de contenu et les plateformes de commerce électronique. 1) PHP a un écosystème riche et un fort soutien-cadre, tels que Laravel et Symfony. 2) L'optimisation des performances peut être obtenue via Opcache et Nginx. 3) PHP8.0 introduit le compilateur JIT pour améliorer les performances. 4) Les applications natives dans le cloud sont déployées via Docker et Kubernetes pour améliorer la flexibilité et l'évolutivité.

PHP vs autres langues: une comparaisonPHP vs autres langues: une comparaisonApr 13, 2025 am 12:19 AM

PHP convient au développement Web, en particulier dans le développement rapide et le traitement du contenu dynamique, mais n'est pas bon dans les applications de la science des données et de l'entreprise. Par rapport à Python, PHP présente plus d'avantages dans le développement Web, mais n'est pas aussi bon que Python dans le domaine de la science des données; Par rapport à Java, PHP fonctionne moins bien dans les applications au niveau de l'entreprise, mais est plus flexible dans le développement Web; Par rapport à JavaScript, PHP est plus concis dans le développement back-end, mais n'est pas aussi bon que JavaScript dans le développement frontal.

PHP vs Python: fonctionnalités et fonctionnalités de basePHP vs Python: fonctionnalités et fonctionnalités de baseApr 13, 2025 am 12:16 AM

PHP et Python ont chacun leurs propres avantages et conviennent à différents scénarios. 1.PHP convient au développement Web et fournit des serveurs Web intégrés et des bibliothèques de fonctions riches. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et une bibliothèque standard puissante. Lors du choix, il doit être décidé en fonction des exigences du projet.

PHP: un langage clé pour le développement WebPHP: un langage clé pour le développement WebApr 13, 2025 am 12:08 AM

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP