跨标签页通信(八):WebSocket

跨标签页通信(八):WebSocket

在现代 Web 开发中,跨标签页通信的需求越来越普遍。无论是实现多标签页之间的数据同步,还是构建实时协作功能,跨标签页通信都能极大地提升用户体验。今天,我们将探讨一种高效且强大的实现方式:WebSocket

一、什么是 WebSocket?

WebSocket 是一种网络通信协议,提供了全双工通信通道,允许客户端和服务器之间进行实时、双向的数据交换。WebSocket 协议在 2008 年诞生,2011 年成为国际标准,所有现代浏览器都已支持。

(一)特点

  • 全双工通信:客户端和服务器可以同时发送和接收消息。
  • 低延迟:相比传统的 HTTP 请求,WebSocket 的通信延迟更低。
  • 双向通信:服务器可以主动向客户端推送消息,客户端也可以主动向服务器发送消息。

(二)适用场景

  • 实时通信:如聊天应用、实时协作工具等。
  • 数据同步:在多个标签页之间同步数据。
  • 游戏:需要低延迟的实时交互。

二、使用 WebSocket 实现跨标签页通信

(一)基本用法

WebSocket 的基本用法包括创建连接、发送消息和接收消息。以下是一个简单的示例:

1. 创建 WebSocket 服务器

使用 Node.js 创建一个 WebSocket 服务器,监听客户端的连接和消息。

javascript 复制代码
// server.js
const WebSocketServer = require('ws').Server;

const wss = new WebSocketServer({ port: 3000 });
const clients = [];

wss.on('connection', (client) => {
    clients.push(client);
    console.log(`有 ${clients.length} 个客户端在线`);

    client.on('message', (msg) => {
        console.log(`收到消息: ${msg}`);
        clients.forEach((c) => {
            if (c !== client) {
                c.send(msg);
            }
        });
    });

    client.on('close', () => {
        const index = clients.indexOf(client);
        clients.splice(index, 1);
        console.log(`有 ${clients.length} 个客户端在线`);
    });
});

console.log('WebSocket 服务器已启动');
2. 创建 WebSocket 客户端

在页面中创建 WebSocket 客户端,连接到服务器并发送/接收消息。

页面一:发送消息
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>页面一</title>
</head>
<body>
    <input type="text" id="msg" placeholder="请输入消息">
    <button id="send">发送消息</button>
    <script>
        const ws = new WebSocket("ws://localhost:3000");
        const send = document.querySelector("#send");
        const msg = document.querySelector("#msg");

        send.onclick = function () {
            if (msg.value.trim() !== "") {
                ws.send(msg.value.trim());
            }
        };

        window.onbeforeunload = function () {
            ws.close();
        };
    </script>
</body>
</html>
页面二:接收消息
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>页面二</title>
</head>
<body>
    <script>
        const ws = new WebSocket("ws://localhost:3000");
        let count = 1;

        ws.onopen = function () {
            ws.onmessage = function (event) {
                const oP = document.createElement("p");
                oP.innerHTML = `第${count}次接收到的消息:${event.data}`;
                document.body.appendChild(oP);
                count++;
            };
        };

        window.onbeforeunload = function () {
            ws.close();
        };
    </script>
</body>
</html>

(二)效果

  1. 打开两个标签页,分别加载页面一和页面二。
  2. 在页面一中输入消息并点击"发送消息"按钮。
  3. 页面二会立即接收到消息,并在页面上显示。

三、注意事项

(一)同源限制

虽然 WebSocket 支持跨域通信,但为了安全起见,建议确保客户端和服务器的协议、域名和端口一致。

(二)安全性

在生产环境中,建议使用 wss://(WebSocket Secure)来加密通信,确保数据的安全性。

(三)性能影响

虽然 WebSocket 的性能开销较小,但在高频率发送消息时,仍需注意对性能的影响。合理控制消息的发送频率可以避免不必要的性能问题。

相关推荐
秋秋小事2 分钟前
React Hooks useContext
前端·javascript·react.js
Jinuss5 分钟前
Vue3源码reactivity响应式篇之reactive响应式对象的track与trigger
前端·vue3
striver_#6 分钟前
百度前端社招面经二
前端
xcnn_6 分钟前
前端入门——案例一:登录界面设计(html+css+js)
前端·css·html
ST.J7 分钟前
前端笔记2025
前端·javascript·css·vue.js·笔记
拉不动的猪8 分钟前
回顾vue中的Props与Attrs
前端·javascript·面试
Jerry44 分钟前
使用 Material 3 在 Compose 中设置主题
前端
耶啵奶膘1 小时前
uni-app头像叠加显示
开发语言·javascript·uni-app
chéng ௹1 小时前
uniapp 封装uni.showToast提示
前端·javascript·uni-app
生擒小朵拉1 小时前
STM32添加库函数
java·javascript·stm32