Rumah hujung hadapan web tutorial js Cara menggunakan Node.js untuk melaksanakan fungsi sembang masa nyata berasaskan web

Cara menggunakan Node.js untuk melaksanakan fungsi sembang masa nyata berasaskan web

Nov 08, 2023 am 11:57 AM
nodejs web Sembang langsung

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

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

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

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

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!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Perbezaan antara nodejs dan vuejs Perbezaan antara nodejs dan vuejs Apr 21, 2024 am 04:17 AM

Node.js ialah masa jalan JavaScript bahagian pelayan, manakala Vue.js ialah rangka kerja JavaScript sisi klien untuk mencipta antara muka pengguna interaktif. Node.js digunakan untuk pembangunan bahagian pelayan, seperti pembangunan API perkhidmatan belakang dan pemprosesan data, manakala Vue.js digunakan untuk pembangunan sisi klien, seperti aplikasi satu halaman dan antara muka pengguna yang responsif.

Adakah nodejs rangka kerja bahagian belakang? Adakah nodejs rangka kerja bahagian belakang? Apr 21, 2024 am 05:09 AM

Node.js boleh digunakan sebagai rangka kerja bahagian belakang kerana ia menawarkan ciri seperti prestasi tinggi, kebolehskalaan, sokongan merentas platform, ekosistem yang kaya dan kemudahan pembangunan.

Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Apr 21, 2024 am 06:13 AM

Untuk menyambung ke pangkalan data MySQL, anda perlu mengikuti langkah berikut: Pasang pemacu mysql2. Gunakan mysql2.createConnection() untuk mencipta objek sambungan yang mengandungi alamat hos, port, nama pengguna, kata laluan dan nama pangkalan data. Gunakan connection.query() untuk melaksanakan pertanyaan. Akhir sekali gunakan connection.end() untuk menamatkan sambungan.

Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apr 21, 2024 am 05:18 AM

Terdapat dua fail berkaitan npm dalam direktori pemasangan Node.js: npm dan npm.cmd Perbezaannya adalah seperti berikut: sambungan berbeza: npm ialah fail boleh laku dan npm.cmd ialah pintasan tetingkap arahan. Pengguna Windows: npm.cmd boleh digunakan daripada command prompt, npm hanya boleh dijalankan dari baris arahan. Keserasian: npm.cmd adalah khusus untuk sistem Windows, npm tersedia merentas platform. Cadangan penggunaan: Pengguna Windows menggunakan npm.cmd, sistem pengendalian lain menggunakan npm.

Adakah nodejs bahasa pembangunan bahagian belakang? Adakah nodejs bahasa pembangunan bahagian belakang? Apr 21, 2024 am 05:09 AM

Ya, Node.js ialah bahasa pembangunan bahagian belakang. Ia digunakan untuk pembangunan bahagian belakang, termasuk mengendalikan logik perniagaan sebelah pelayan, mengurus sambungan pangkalan data dan menyediakan API.

Apakah pembolehubah global dalam nodejs Apakah pembolehubah global dalam nodejs Apr 21, 2024 am 04:54 AM

Pembolehubah global berikut wujud dalam Node.js: Objek global: modul Teras global: proses, konsol, memerlukan pembolehubah persekitaran Runtime: __dirname, __filename, __line, __column Constants: undefined, null, NaN, Infinity, -Infinity

Adakah terdapat perbezaan besar antara nodejs dan java? Adakah terdapat perbezaan besar antara nodejs dan java? Apr 21, 2024 am 06:12 AM

Perbezaan utama antara Node.js dan Java ialah reka bentuk dan ciri: Didorong peristiwa vs. didorong benang: Node.js dipacu peristiwa dan Java dipacu benang. Satu-benang vs. berbilang benang: Node.js menggunakan gelung acara satu-benang dan Java menggunakan seni bina berbilang benang. Persekitaran masa jalan: Node.js berjalan pada enjin JavaScript V8, manakala Java berjalan pada JVM. Sintaks: Node.js menggunakan sintaks JavaScript, manakala Java menggunakan sintaks Java. Tujuan: Node.js sesuai untuk tugas intensif I/O, manakala Java sesuai untuk aplikasi perusahaan besar.

Mana satu untuk dipilih antara nodejs dan java? Mana satu untuk dipilih antara nodejs dan java? Apr 21, 2024 am 04:40 AM

Node.js dan Java masing-masing mempunyai kebaikan dan keburukan dalam pembangunan web, dan pilihan bergantung pada keperluan projek. Node.js cemerlang dalam aplikasi masa nyata, pembangunan pesat dan seni bina perkhidmatan mikro, manakala Java cemerlang dalam sokongan, prestasi dan keselamatan gred perusahaan.

See all articles