Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana untuk Melaksanakan Kemas Kini Komen Masa Nyata dalam Templat Jinja2 Menggunakan WebSockets dan FastAPI?
Mendapatkan Senarai Item Kemas Kini dalam Templat Jinja2 Menggunakan FastAPI
Dalam tutorial ini, kami menunjukkan cara melaksanakan aplikasi sembang masa nyata menggunakan FastAPI dan Jinja2 untuk kemas kini dinamik senarai komen. Aplikasi ini memanfaatkan WebSockets untuk mewujudkan saluran komunikasi dua hala antara pelayan dan berbilang pelanggan.
Masalah:
Bayangkan membina sistem ulasan blog di mana ulasan baharu perlu dibuat secara dinamik ditambahkan pada bahagian hadapan tanpa memerlukan penyegaran halaman. Templat Jinja2 digunakan untuk memberikan ulasan sedia ada pada halaman, tetapi mekanisme diperlukan untuk mendapatkan dan memaparkan ulasan yang baru ditambah dalam masa nyata.
Penyelesaian:
Kepada mencapai fungsi ini, kami memperkenalkan WebSockets, teknologi yang membolehkan komunikasi dua hala masa nyata melalui sambungan TCP tunggal. Dengan melaksanakan WebSockets dengan FastAPI dan Jinja2, kami boleh mewujudkan sambungan berterusan antara pelayan dan klien, membolehkan pelayan menyiarkan ulasan baharu kepada semua pelanggan yang disambungkan dalam masa nyata.
Melaksanakan WebSockets:
Untuk menyediakan WebSockets dalam FastAPI, kami mencipta titik akhir WebSocket yang mengendalikan sambungan masuk dan mewujudkan sambungan khusus untuk setiap pelanggan. Kod berikut menunjukkan titik akhir WebSocket kami:
<code class="python">@app.websocket("/ws") async def websocket_endpoint(websocket: WebSocket): await manager.connect(websocket) try: while True: data = await websocket.receive_json() comments.append(Comment(data['author'], data['content'])) await manager.broadcast(data) except (WebSocketDisconnect, ConnectionClosed): manager.disconnect(websocket)</code>
Dalam kod ini:
Mengemas kini Templat Jinja2:
Untuk memaparkan ulasan yang dikemas kini dalam templat Jinja2, kami menggunakan JavaScript dan WebSockets untuk mendengar mesej masuk daripada pelayan dan menambah secara dinamik ulasan baharu pada halaman tersebut. Dalam templat index.html kami, kami memasukkan kod JavaScript berikut:
<code class="html"><script> var ws = new WebSocket("ws://localhost:8000/ws"); ws.onmessage = function(event) { var comments = document.getElementById('comments'); var comment = document.createElement('li'); var jsonObj = JSON.parse(event.data); var authorNode = document.createElement('h3'); authorNode.innerHTML = jsonObj.author; var contentNode = document.createElement('p'); contentNode.innerHTML = jsonObj.content; comment.appendChild(authorNode); comment.appendChild(contentNode); comments.appendChild(comment); }; </script></code>
Kod JavaScript ini:
Kesimpulan
Dengan menyepadukan WebSockets dengan FastAPI dan Jinja2, kami telah melaksanakan sistem ulasan dinamik yang membenarkan kemas kini masa nyata. Teknik ini boleh digunakan pada pelbagai senario di mana anda perlu menghantar dan menerima mesej atau data antara pelanggan dan pelayan dalam masa nyata, memberikan pengalaman pengguna yang sangat interaktif dan responsif.
Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Kemas Kini Komen Masa Nyata dalam Templat Jinja2 Menggunakan WebSockets dan FastAPI?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!