Maison >interface Web >tutoriel CSS >Templage avec Jinja2 dans Flask: Essentials

Templage avec Jinja2 dans Flask: Essentials

Lisa Kudrow
Lisa Kudroworiginal
2025-02-28 09:10:17384parcourir

Jinja2: moteur de modèle efficace dans les applications de balles

Jinja2 est un moteur de modèle écrit pur Python qui fournit une syntaxe non XML de type Django, tout en prenant en charge les expressions en ligne et les environnements de sable en option. Il est compact, rapide et facile à utiliser et est un moteur de modèle autonome. Flask est un minuscule framework Web basé sur Python qui vous permet d'écrire des applications Web rapidement et efficacement.

Cette série de tutoriels expliquera les connaissances de base des modèles Jinja2 du point de vue du ballon. La section suivante introduira des sujets de modèles avancés et apprendra comment disposer des modèles de manière modulaire et évolutive dans les applications basées sur Flask.

Ce tutoriel suppose que vous avez maîtrisé les bases du flacon et comprenez les meilleures pratiques pour la configuration des environnements à l'aide de VirtualEnv pour le développement d'applications Python.

Pack d'installation

FLASK est livré avec Jinja2, nous n'avons donc qu'à installer Flask. Cette série de tutoriels recommande d'utiliser la version de développement de Flask, qui comprend une prise en charge de ligne de commande plus stable, ainsi que de nombreuses autres fonctionnalités et améliorations.

<code class="language-bash">pip install https://github.com/mitsuhiko/flask/tarball/master</code>

Pourquoi avez-vous besoin d'un moteur de modèle?

Dans Flask, nous pouvons écrire une application Web complète sans moteur de modèle tiers. Regardons un exemple simple des blocs if, else et {% %}. Mettez à jour la page home.html comme suit:

flask_app / modèles / home.html

<code class="language-html+jinja">{% extends 'base.html' %}

{% block container %}
<div class="top-pad">
    {% for id, product in products.items() %}
    <div class="well">
    <h2>
        <a href="https://www.php.cn/link/0bbfd30c6d7efe2fff86061e79c010db'product',%20key=id)%20%7D%7D">{{product['name']}}</a>
        <small>$ {{ product['price']}}</small>
    </h2>
    </div>
    {% endfor %}
</div>
{% endblock %}</code>

Regardez comment ce modèle étend le filtre supérieur comme indiqué ci-dessous:

<code class="language-html+jinja">{% extends 'base.html' %}

{% block container %}
<div class="top-pad">
    {% for id, product in products.items() %}
    <div class="well">
    <h2>
        <a href="https://www.php.cn/link/0bbfd30c6d7efe2fff86061e79c010db'product',%20key=id)%20%7D%7D">{{product['name']|upper}}</a>
        <small>$ {{ product['price']}}</small>
    </h2>
    </div>
    {% endfor %}
</div>
{% endblock %}</code>

Maintenant, si vous exécutez le serveur, vous devez remarquer que le nom du produit est entièrement en majuscule.

Templating With Jinja2 in Flask: Essentials

Résumé

Dans ce tutoriel, nous avons appris à utiliser la structure du modèle de mise en page Jinja2 dans une application basée sur Flask. Nous avons également appris à utiliser des blocs pour tirer parti de l'héritage dans les modèles.

Dans la prochaine partie de cette série, nous apprendrons à rédiger des filtres personnalisés, des processeurs de contexte personnalisés et des macros.

Cet article a été mis à jour et contient des contributions d'Esther Vaati. Esther est un développeur de logiciels et contributeur à Envato TUTS.

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
Article précédent:onClick (attribut HTML)Article suivant:onClick (attribut HTML)