Flacon - Modèles
Il est possible de renvoyer la sortie d'une fonction liée à une certaine URL sous forme de HTML. Par exemple, dans le script suivant,hello() la fonction rendra ‘Hello World’ avec <h1> étiquette qui y est attachée.
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '<html><body><h1>Hello World</h1></body></html>'
if __name__ == '__main__':
app.run(debug = True)
Cependant, générer du contenu HTML à partir du code Python est fastidieux, en particulier lorsque des données variables et des éléments du langage Python tels que des conditions ou des boucles doivent être placés. Cela nécessiterait des échappements fréquents du HTML.
C'est là que l'on peut profiter de Jinja2moteur de template, sur lequel Flask est basé. Au lieu de renvoyer du code HTML à partir de la fonction, un fichier HTML peut être rendu par lerender_template() fonction.
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return render_template(‘hello.html’)
if __name__ == '__main__':
app.run(debug = True)
Flask essaiera de trouver le fichier HTML dans le dossier des modèles, dans le même dossier dans lequel ce script est présent.
- Dossier d'application
- Hello.py
- templates
- hello.html
Le terme ‘web templating system’fait référence à la conception d'un script HTML dans lequel les données variables peuvent être insérées dynamiquement. Un système de modèle Web comprend un moteur de modèle, une sorte de source de données et un processeur de modèle.
Utilisations du flacon jinja2moteur de modèle. Un modèle Web contient des espaces réservés de syntaxe HTML intercalés pour les variables et les expressions (dans ce cas les expressions Python) qui sont des valeurs remplacées lorsque le modèle est rendu.
Le code suivant est enregistré sous hello.html dans le dossier des modèles.
<!doctype html>
<html>
<body>
<h1>Hello {{ name }}!</h1>
</body>
</html>
Ensuite, exécutez le script suivant à partir du shell Python.
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/hello/<user>')
def hello_name(user):
return render_template('hello.html', name = user)
if __name__ == '__main__':
app.run(debug = True)
Lorsque le serveur de développement démarre, ouvrez le navigateur et entrez l'URL sous la forme - http://localhost:5000/hello/mvl
le variable une partie de l'URL est insérée à {{ name }} espace réservé.
le jinja2 Le moteur de modèle utilise les délimiteurs suivants pour s'échapper du HTML.
- {% ...%} pour les déclarations
- {{...}} pour que les expressions s'impriment dans la sortie du modèle
- {# ... #} pour les commentaires non inclus dans la sortie du modèle
- # ... ## pour les instructions de ligne
Dans l'exemple suivant, l'utilisation d'une instruction conditionnelle dans le modèle est illustrée. La règle d'URL vers lehello()La fonction accepte le paramètre entier. Il est transmis auhello.htmlmodèle. À l'intérieur, la valeur du nombre reçu (points) est comparée (supérieure ou inférieure à 50) et en conséquence le HTML est rendu conditionnellement.
Le script Python est le suivant -
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/hello/<int:score>')
def hello_name(score):
return render_template('hello.html', marks = score)
if __name__ == '__main__':
app.run(debug = True)
Script de modèle HTML de hello.html est comme suit -
<!doctype html>
<html>
<body>
{% if marks>50 %}
<h1> Your result is pass!</h1>
{% else %}
<h1>Your result is fail</h1>
{% endif %}
</body>
</html>
Notez que les instructions conditionnelles if-else et endif sont entourés d'un délimiteur {%..%}.
Exécutez le script Python et visitez l'URL http://localhost/hello/60 et alors http://localhost/hello/30 pour voir la sortie du HTML changer conditionnellement.
Les constructions de boucle Python peuvent également être utilisées dans le modèle. Dans le script suivant, leresult() la fonction envoie un objet dictionnaire au modèle results.html quand URL http://localhost:5000/result est ouvert dans le navigateur.
La partie Template de result.html emploie un for loop pour rendre les paires clé et valeur d'un objet dictionnaire result{} sous forme de cellules d'un tableau HTML.
Exécutez le code suivant à partir du shell Python.
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/result')
def result():
dict = {'phy':50,'che':60,'maths':70}
return render_template('result.html', result = dict)
if __name__ == '__main__':
app.run(debug = True)
Enregistrez le script HTML suivant sous result.html dans le dossier des modèles.
<!doctype html>
<html>
<body>
<table border = 1>
{% for key, value in result.items() %}
<tr>
<th> {{ key }} </th>
<td> {{ value }} </td>
</tr>
{% endfor %}
</table>
</body>
</html>
Ici, à nouveau les instructions Python correspondant à la For boucle sont entourés de {% ..%} alors que les expressions key and value sont mis à l'intérieur {{ }}.
Une fois le développement lancé, ouvrez http://localhost:5000/result dans le navigateur pour obtenir la sortie suivante.