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

Templage avec Jinja2 dans Flask: Essentials

Lisa Kudrow
Libérer: 2025-02-28 09:10:17
original
381 Les gens l'ont consulté

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.

pip install https://github.com/mitsuhiko/flask/tarball/master
Copier après la connexion

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

{% 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', key=id) }}">{{product['name']}}</a>
        <small>$ {{ product['price']}}</small>
    </h2>
    </div>
    {% endfor %}
</div>
{% endblock %}
Copier après la connexion

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

{% 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', key=id) }}">{{product['name']|upper}}</a>
        <small>$ {{ product['price']}}</small>
    </h2>
    </div>
    {% endfor %}
</div>
{% endblock %}
Copier après la connexion

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 de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal