Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Mengelakkan SyntaxErrors JavaScript Apabila Menggunakan Templat Jinja dan Data JSON?

Bagaimana untuk Mengelakkan SyntaxErrors JavaScript Apabila Menggunakan Templat Jinja dan Data JSON?

Barbara Streisand
Barbara Streisandasal
2024-12-11 11:03:11218semak imbas

How to Avoid JavaScript SyntaxErrors When Using Jinja Templates and JSON Data?

JavaScript menimbulkan SyntaxError dengan data yang diberikan dalam templat Jinja

Persekitaran Jinja Flask secara automatik melepaskan data yang diberikan dalam templat HTML untuk mengelakkan isu keselamatan. Apabila menghantar objek Python untuk dianggap sebagai JSON, adalah penting untuk mengendalikan pelarian ini dengan betul untuk mengelakkan ralat sintaks dalam JavaScript.

Menggunakan Penapis tojson

Untuk menjadikan objek Python sebagai JSON selamat, gunakan penapis tojson:

return render_template('tree.html', tree=tree)

Dalam templat, gunakan:

var tree = {{ tree|tojson }};

Ini dengan selamat membuang data ke JSON dan menandakannya sebagai selamat untuk mengelakkan melarikan diri.

Berurusan dengan JSON Pra-Dibuang

Jika JSON telah pun telah dibuang ke rentetan, gunakan penapis selamat untuk menandakannya sebagai selamat untuk dipaparkan:

return render_template('tree.html', tree=json.dumps(tree))

Dalam templat, gunakan:

var tree = {{ tree|safe }};

Menggunakan Markup

Sebagai alternatif, anda boleh membalut rentetan dalam Markup sebelum membuat persembahan:

return render_template('tree.html', tree=Markup(json.dumps(tree)))

Dalam templat, anda boleh menggunakan nilai sebagai:

var tree = {{ tree }};

Mengelakkan JSON untuk Jinja Gunakan

Jika anda menggunakan data dalam Jinja dan bukannya menghantarnya ke JavaScript, jangan gunakan tojson. Sebaliknya, hantar data Python secara terus dan gunakannya seperti biasa dalam templat:

return render_template('tree.html', tree=tree)
{% for item in tree %}
    <li>{{ item }}</li>
{% endfor %}

Atas ialah kandungan terperinci Bagaimana untuk Mengelakkan SyntaxErrors JavaScript Apabila Menggunakan Templat Jinja dan Data JSON?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn