SharedWorker实现多页面通信的完整示例

admin2个月前 (10-11)it知识275

以下是一个使用SharedWorker实现多页面通信的完整示例,包含HTML页面和SharedWorker脚本:

<!DOCTYPE html><html><head>    <meta charset="UTF-8">    <title>SharedWorker示例</title>    <style>        body { font-family: Arial, sans-serif; max-width: 800px; margin: 0 auto; padding: 20px; }        .container { border: 1px solid #ddd; padding: 20px; margin-bottom: 20px; }        button { padding: 8px 16px; background: #4CAF50; color: white; border: none; cursor: pointer; }        button:hover { background: #45a049; }        #messages { height: 200px; overflow-y: scroll; border: 1px solid #eee; padding: 10px; }    </style></head><body>    <div class="container">        <h2>SharedWorker通信示例</h2>        <div>            <input type="text" id="messageInput" placeholder="输入消息">            <button id="sendBtn">发送消息</button>        </div>        <div id="messages"></div>    </div>    <script>        const worker = new SharedWorker('worker.js');        const messageInput = document.getElementById('messageInput');        const sendBtn = document.getElementById('sendBtn');        const messagesDiv = document.getElementById('messages');        // 启动端口通信        worker.port.start();        // 发送消息        sendBtn.addEventListener('click', () => {            const message = messageInput.value;            if (message) {                worker.port.postMessage({                    type: 'message',                    content: message,                    timestamp: new Date().toLocaleTimeString()                });                messageInput.value = '';            }        });        // 接收消息        worker.port.onmessage = (e) => {            const { type, content, timestamp } = e.data;            if (type === 'message') {                const messageElement = document.createElement('div');                messageElement.textContent = `${timestamp}: ${content}`;                messagesDiv.appendChild(messageElement);                messagesDiv.scrollTop = messagesDiv.scrollHeight;            } else if (type === 'connection') {                const infoElement = document.createElement('div');                infoElement.textContent = `系统消息: ${content}`;                infoElement.style.color = '#666';                messagesDiv.appendChild(infoElement);            }        };    </script></body></html>//worker.js// 跟踪所有连接的端口const connectedPorts = new Set();// 处理新连接onconnect = function(e) {    const port = e.ports[0];    connectedPorts.add(port);        // 通知新连接    broadcastMessage({        type: 'connection',        content: `新客户端已连接,当前连接数: ${connectedPorts.size}`,        timestamp: new Date().toLocaleTimeString()    });    // 消息处理    port.onmessage = function(e) {        if (e.data.type === 'message') {            // 广播消息给所有连接的客户端            broadcastMessage(e.data);        }    };    // 端口关闭时清理    port.addEventListener('close', () => {        connectedPorts.delete(port);        broadcastMessage({            type: 'connection',            content: `客户端断开,当前连接数: ${connectedPorts.size}`,            timestamp: new Date().toLocaleTimeString()        });    });    port.start();};// 广播消息给所有客户端function broadcastMessage(message) {    connectedPorts.forEach(port => {        port.postMessage(message);    });}

代码功能说明: 

 主页面通过Sha[文]redWorker构造函数创[章]建共享线程实例,并通过por[来]t属性进行通信

 SharedWo[自]rker脚本使用onconn[一]ect事件处理新连接,每个连[道]接对应一个MessagePo[,]rt对象 

 实现了消息广播功[一]能,所有连接的页面都能收到其[个]他页面发送的消息 [分]

包含连接状态跟踪,实时显示当[享]前连接数使用结构化消息格式,[的]

包含消息类型、内容和时间戳

使用方法: 

在浏览器中打开多个index[网].html页面(同源)在一个[站]页面发送消息,

其他所有页面都会实时显示该消[文]息系统会自动显示连接和断开通[章]知 

注意事项:所有页面必须同源([来]相同协议、域名和端口)才能共[自]享同一个SharedWork[一]er

需要显式调用port.sta[道]rt()方法才能接收消息&n[,]bsp;

SharedWorker生命周期独立于页面,即使所有页面关闭,Worker仍可能保持运行

标签: 分享IT知识

相关文章

职场人如何写季度总结

作为职场人,写季度总结是一个展示自己工作成果和总结经验教训的机会。以下是一些撰写季度总结的建议:明确总结的目的:季度总结的目的是为了向上级领导汇报本季度的工作进展、成果和教训,以及下季度的工作计划。因...

技术与艺术的融合:创造无比魅力的结合

在人类文明的发展史上,技术与艺术如同一对形影不离的伙伴,共同推动了人类社会的进步。随着科技的飞速发展,技术与艺术的融合愈发紧密,为我们揭示了一个全新的视角,让我们重新审视这两股强大的力量。在当今数字化...

享受工作:找到事业与生活的平衡点

工作是我们日常生活中不可或缺的一部分。我们花费大量的时间和精力在工作中,因此,如何享受工作并找到事业与生活的平衡点就显得尤为重要。在这篇文章中,我们将探讨如何享受工作,让事业和生活愉快并行。首先,了解...

关于夏天

在一个炎热的午后,阳光穿过树叶的缝隙,洒在公园的草地上。空气中弥漫着夏日的气息,那是炎热中夹杂着淡淡的花香,还有草地的清新味道。在这个充满活力的季节,夏天以其独特的方式展示着它的魅力。夏天是一个充满色...

湖边

湖边,一片静谧的美好。清晨的阳光洒在湖面上,波光粼粼,让人心旷神怡。湖上的荷叶轻轻摇曳,荷花争奇斗艳,仿佛在向人们展示着它们的美丽。湖边的柳树依依,芦苇丛生,形成了一道道天然的屏障,让人感到一种隐秘的...

夏天的台风

夏天,是一个充满活力和生命力的季节,但同时也伴随着台风的出现。每年的这个时期,台风如同一股强大的自然力量,给人们的生命和财产带来了一定的威胁。在台风的肆虐中,可以看到大自然的威力与无情。台风带来的强风...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。