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
Lepaskan: 2024-12-25 16:33:20
asal
384 orang telah melayarinya

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)
Salin selepas log masuk

Pendekatan Alternatif:

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

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)
Salin selepas log masuk

Pelaksanaan:

Dalam templat Jinja:

var data = {{ data }};

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

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

{% for item in tree %}
    <li>{{ item }}</li>
{% endfor %}
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan