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

PHPz
Lepaskan: 2023-11-08 11:57:50
asal
1408 orang telah melayarinya

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!

Label berkaitan:
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan