Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Membetulkan SyntaxErrors JavaScript Apabila Menghuraikan Data JSON yang Dihasilkan Jinja?

Bagaimana untuk Membetulkan SyntaxErrors JavaScript Apabila Menghuraikan Data JSON yang Dihasilkan Jinja?

Susan Sarandon
Susan Sarandonasal
2024-12-25 16:33:20386semak imbas

How to Fix JavaScript SyntaxErrors When Parsing Jinja-Rendered JSON Data?

JavaScript SyntaxRalat dengan Jinja-Rendered Data

Masalah: Apabila cuba menghuraikan data JSON yang diberikan dalam Templat HTML Jinja menggunakan JavaScript, SyntaxError ditemui, menunjukkan token '&' yang tidak dijangka.

Punca: Persekitaran Jinja Flask secara automatik melepaskan data yang diberikan dalam templat HTML atas sebab keselamatan. Ini bermasalah apabila menghantar objek JSON ke JavaScript, kerana aksara yang dilepaskan mengganggu penghuraian.

Penyelesaian: Gunakan Penapis tojson Flask atau Penanda untuk Menandai Data sebagai Selamat

Untuk selesaikan isu ini, gunakan penapis tojson Flask, yang membuang data ke dalam JSON dan menandakannya selamat untuk dipaparkan dalam JavaScript.

return render_template("template.html", data=tree|tojson)

Pendekatan Alternatif:

  • Penapis Selamat (tidak digunakan): Penapis ini, walaupun tidak digunakan, menandakan data sebagai selamat tanpa JSON penukaran.
var data = {{ tree|safe }};
  • Pembungkus Penanda: Membungkus rentetan JSON dalam Penanda sebelum pemaparan adalah bersamaan dengan penapis selamat.
return render_template("template.html", data=Markup(json.dumps(tree)))

Data Python Langsung Penggunaan:

Jika data yang diberikan tidak bertujuan untuk JavaScript, pertimbangkan untuk menghantar data Python secara langsung tanpa menggunakan penukaran atau penapis JSON.

return render_template("template.html", data=tree)

Pelaksanaan:

Dalam templat Jinja:

var data = {{ data }};

for (i in obj) {
   document.write(obj[i].text + "<br />");
}

Sebagai alternatif, data Jinja boleh digunakan terus tanpa penghuraian JavaScript:

{% for item in tree %}
    <li>{{ item }}</li>
{% endfor %}

Atas ialah kandungan terperinci Bagaimana untuk Membetulkan SyntaxErrors JavaScript Apabila Menghuraikan Data JSON yang Dihasilkan Jinja?. 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