Maison > interface Web > js tutoriel > Comment transmettre des données de Flask à JavaScript dans des modèles utilisant Jinja2 ?

Comment transmettre des données de Flask à JavaScript dans des modèles utilisant Jinja2 ?

Susan Sarandon
Libérer: 2024-10-27 21:58:01
original
1161 Les gens l'ont consulté

How to Pass Data from Flask to JavaScript in Templates Using Jinja2?

Transmission de données de Flask vers JavaScript dans des modèles

Lors de la récupération de données à partir d'une API dans une application Flask, il peut être nécessaire de transmettre ces informations en JavaScript dans le modèle correspondant. Cet article explique comment y parvenir en tirant parti de la puissance des modèles Jinja2.

Dans Flask, la fonction render_template nous permet de transmettre des variables aux modèles HTML. Cependant, pour rendre ces variables disponibles en JavaScript, une étape supplémentaire est requise.

Jinja2, le moteur de création de modèles utilisé par Flask, fournit une syntaxe qui permet l'intégration d'expressions Python dans des modèles. Cela signifie que nous pouvons utiliser {{ variable }} n'importe où dans le modèle, y compris dans les scripts JavaScript.

Par exemple, considérons la route Flask suivante qui récupère les coordonnées d'une API :

<code class="python">@app.route('/')
def get_data():
    events = api.call(get_event, arg0, arg1)
    geocode = event['latitude'], event['longitude']
    return render_template('get_data.html', geocode=geocode)</code>
Copier après la connexion

Dans le modèle correspondant, nous pouvons passer la variable géocode à JavaScript comme ceci :

<code class="html"><script>
var someJavaScriptVar = '{{ geocode[1] }}';
</script></code>
Copier après la connexion

Cela nous permet d'accéder à la valeur de géocode[1] comme someJavaScriptVar dans notre code JavaScript.

Alternativement, pour transmettre la variable de géocodage sous forme de tableau, nous pouvons générer la définition du tableau dans le modèle :

<code class="html"><script>
var myGeocode = ['{{ geocode[0] }}', '{{ geocode[1] }}'];
</script></code>
Copier après la connexion

Jinja2 prend également en charge des constructions plus avancées, telles que des boucles et des instructions if, qui peuvent être utilisées pour simplifie la génération de structures de données complexes.

De plus, le filtre tojson peut être utilisé pour convertir le tuple de géocodage en chaîne JSON, le rendant plus adapté à une utilisation en JavaScript :

<code class="html"><script>
var myGeocode = {{ geocode | tojson }};
</script></code>
Copier après la connexion

Grâce à ces techniques, les développeurs peuvent partager de manière transparente des données entre Flask et JavaScript, permettant ainsi des applications Web interactives et dynamiques.

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!

source:php.cn
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