


Cara menggunakan Node.js untuk melaksanakan fungsi sembang masa nyata berasaskan web
Dengan perkembangan pesat Internet, fungsi komunikasi masa nyata telah menjadi ciri yang mesti ada untuk banyak laman web dan aplikasi. Sebagai persekitaran berjalan JavaScript I/O tak segerak yang ringan, cekap dan dipacu peristiwa, Node.js boleh membina aplikasi masa nyata berprestasi tinggi dengan cepat, jadi ia telah menjadi pilihan terbaik untuk membangunkan fungsi komunikasi masa nyata. Artikel ini akan memperkenalkan secara terperinci cara menggunakan Node.js untuk melaksanakan fungsi sembang masa nyata berasaskan web dan memberikan contoh kod khusus.
Pertama sekali, kita perlu membina pelayan web asas, yang boleh dilaksanakan menggunakan modul http yang disertakan dengan Node.js. Kod khusus adalah seperti berikut:
const http = require('http'); const server = http.createServer(); server.listen(3000, () => { console.log('服务器已启动,监听端口:3000'); });
Seterusnya, kita perlu menggunakan modul socket.io untuk melaksanakan fungsi komunikasi masa nyata. Socket.io ialah perpustakaan komunikasi masa nyata berdasarkan protokol WebSocket dan serasi dengan pelbagai kaedah penghantaran Ia menyokong komunikasi dua hala antara pelanggan dan pelayan, dan sangat sesuai untuk senario sembang masa nyata. Arahan untuk memasang modul socket.io adalah seperti berikut:
npm install socket.io
Selepas pemasangan selesai, kami boleh menggunakan modul socket.io pada bahagian pelayan untuk mendayakan fungsi komunikasi masa nyata. Kod khusus adalah seperti berikut:
const http = require('http'); const server = http.createServer(); const io = require('socket.io')(server); io.on('connection', (socket) => { console.log('有一个用户已连接'); socket.on('disconnect', () => { console.log('有一个用户已断开连接'); }); socket.on('chat message', (msg) => { console.log('收到一条新消息:' + msg); io.emit('chat message', msg); }); }); server.listen(3000, () => { console.log('服务器已启动,监听端口:3000'); });
Dalam kod di atas, kami mendengar acara sambungan socket.io, yang bermaksud ia akan dicetuskan apabila pengguna menyambung. Apabila pengguna menyambung, kami akan mengeluarkan mesej gesaan pada konsol. Seterusnya, kami mendengar peristiwa putus sambungan socket.io, yang bermaksud ia akan dicetuskan apabila pengguna memutuskan sambungan. Apabila pengguna memutuskan sambungan, kami juga akan mengeluarkan mesej segera pada konsol. Akhirnya, kami mendengar acara mesej sembang tersuai, yang menunjukkan penerimaan mesej baharu daripada pengguna. Apabila mesej baharu tiba, kami menyiarkannya kepada semua pengguna dalam talian.
Di sisi pelanggan, kami perlu memperkenalkan modul socket.io-client untuk menyambung ke pelayan dan merealisasikan paparan dan penghantaran sembang masa nyata. Kod khusus adalah seperti berikut:
<!DOCTYPE html> <html> <head> <title>实时聊天</title> <script src="https://cdn.socket.io/socket.io-3.0.1.min.js"></script> <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script> <script> $(function() { var socket = io(); $('form').submit(function(e) { e.preventDefault(); // 阻止表单提交 var msg = $('#m').val(); socket.emit('chat message', msg); // 发送消息到服务器 $('#m').val(''); return false; }); socket.on('chat message', function(msg) { // 收到新消息 $('#messages').append($('<li>').text(msg)); }); }); </script> </head> <body> <ul id="messages"></ul> <form> <input type="text" id="m" autocomplete="off" /> <button>发送</button> </form> </body> </html>
Dalam kod di atas, kami memperkenalkan modul socket.io-client dan jQuery. Selepas halaman dimuatkan, kami membuat sambungan dengan pelayan dan mendengar acara mesej sembang, yang bermaksud ia akan dicetuskan apabila mesej baharu diterima. Apabila mesej baharu tiba, kami menambahkannya pada senarai mesej pada halaman. Pada masa yang sama, apabila pengguna memasukkan teks dalam kotak input dan mengklik butang hantar, kami menghantar mesej ke pelayan.
Ringkasnya, kami telah melaksanakan fungsi sembang masa nyata berdasarkan protokol WebSocket dengan menggunakan modul Node.js dan socket.io. Dalam projek sebenar, kami juga boleh memanjangkan data seperti storan berterusan, pengesahan identiti dan push mesej untuk menyediakan perkhidmatan komunikasi masa nyata yang lebih kaya.
Atas ialah kandungan terperinci Cara menggunakan Node.js untuk melaksanakan fungsi sembang masa nyata berasaskan web. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Enjin JavaScript yang berbeza mempunyai kesan yang berbeza apabila menguraikan dan melaksanakan kod JavaScript, kerana prinsip pelaksanaan dan strategi pengoptimuman setiap enjin berbeza. 1. Analisis leksikal: Menukar kod sumber ke dalam unit leksikal. 2. Analisis Tatabahasa: Menjana pokok sintaks abstrak. 3. Pengoptimuman dan Penyusunan: Menjana kod mesin melalui pengkompil JIT. 4. Jalankan: Jalankan kod mesin. Enjin V8 mengoptimumkan melalui kompilasi segera dan kelas tersembunyi, Spidermonkey menggunakan sistem kesimpulan jenis, menghasilkan prestasi prestasi yang berbeza pada kod yang sama.

Aplikasi JavaScript di dunia nyata termasuk pengaturcaraan sisi pelayan, pembangunan aplikasi mudah alih dan Internet of Things Control: 1. Pengaturcaraan sisi pelayan direalisasikan melalui node.js, sesuai untuk pemprosesan permintaan serentak yang tinggi. 2. Pembangunan aplikasi mudah alih dijalankan melalui reaktnatif dan menyokong penggunaan silang platform. 3. Digunakan untuk kawalan peranti IoT melalui Perpustakaan Johnny-Five, sesuai untuk interaksi perkakasan.

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing

Artikel ini menunjukkan integrasi frontend dengan backend yang dijamin oleh permit, membina aplikasi edtech SaaS yang berfungsi menggunakan Next.Js. Frontend mengambil kebenaran pengguna untuk mengawal penglihatan UI dan memastikan permintaan API mematuhi dasar peranan

JavaScript adalah bahasa utama pembangunan web moden dan digunakan secara meluas untuk kepelbagaian dan fleksibiliti. 1) Pembangunan front-end: Membina laman web dinamik dan aplikasi satu halaman melalui operasi DOM dan kerangka moden (seperti React, Vue.js, sudut). 2) Pembangunan sisi pelayan: Node.js menggunakan model I/O yang tidak menyekat untuk mengendalikan aplikasi konkurensi tinggi dan masa nyata. 3) Pembangunan aplikasi mudah alih dan desktop: Pembangunan silang platform direalisasikan melalui reaktnatif dan elektron untuk meningkatkan kecekapan pembangunan.

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver Mac版
Alat pembangunan web visual

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Dreamweaver CS6
Alat pembangunan web visual