当前位置: 首页 > article >正文

多标签页之间的通信

解决方案有两种思路:浏览器端解决方案、服务器端解决方案。

一、浏览器端解决方案:

思路:本地数据存储

<!-- index01.html -->
<input id="name"> 
<input type="button" id="btn" value="提交">

1. localStorage

原理:localStorage 在所有同源 url 中都是共享的(localStorage 存储在客户端硬盘,两个页面位于不同浏览器也可以共享)。

注意:在不同的页面修改 localStorage,才能够被监听到,相同页面、重复设置相同的值,都是无法被监听的。

用法:

// index01.html
btn.addEventListener('onclick', function () {
    localStorage.setItem("key", value);
});
// index02.html
window.addEventListener("storage", function (e) {
    console.log(e);
});

2. Cookie

原理:同源可访问。

注意:cookie 无法监听变化,需要通过一个定时器,每隔一段时间获取一次数据。

用法:

// index01.html
document.cookie = "key=" + value;
// index02.html
function getCookie(key) {
    // 从cookie中获取并解析数据
    return JSON.parse("{\"" + document.cookie.replace(/;\s+/gim,"\",\"").replace(/=/gim, "\":\"") + "\"}")[key]; 
} 
setInterval(function(){ 
    console.log("key=" + getCookie("key")); 
}, 5000);

二、服务器端解决方案:

1. websocket(H5新增的协议)

原理:websocket建立的是全双工通讯,服务器也可以主送发送数据给客户端。只要让服务器作为中转站,就可以实现两个页面的通讯。

// index01.html 与服务器建立 全双工 通讯(index02.html同理)
const socket = new WebSocket('ws://localhost:8080');  // 与服务器建立全双工连接

// 连接建立时触发
socket.addEventListener('open', function (event) {
    socket.send('Hello Server!');   // 发送数据给服务器
});

// 客户端接收服务端数据时触发
socket.addEventListener('message', function (event) {
    console.log('Message from server ', event.data);  // 监听服务器传回的数据
});

socket.send(); // 发送数据

2. SharedWorker(H5新特性)

首先新建一个worker.js,不必打包到项目中,直接放到服务器即可:

let data = '';
let onconnect = function (e) {
    let port = e.ports[0];
    port.onmessage = function (e) {
        if (e.data === 'getData') {
            port.postMessage(data)
        } else {
            data = e.data
        }
    }
}

index01.js、index02.js:

const worker = new SharedWorker('worker.js');

// 与worker建立连接
worker.port.start();

worker.port.addEventListener('message', function (e) {
    console.log('worker发来的数据:', e.data);
}, false);

setBtn.addEventListener('click', function (e) {
    worker.port.postMessage(value);
}, false);

getBtn.addEventListener('click', function (e) {
    // 获取发送到worker的数据(约定 'getData' 是获取数据)。
    worker.port.postMessage('getData');
}, false);


http://www.kler.cn/a/134452.html

相关文章:

  • RPC 源码解析~Apache Dubbo
  • 镭速大文件传输视频文件预览实现原理
  • 设计模式-工厂模式/抽象工厂模式
  • C# .NetCore 使用 Flurl.Http 与 HttpClient 请求处理流式响应
  • 【C#深度学习之路】如何使用C#实现Yolo8/11 Segment 全尺寸模型的训练和推理
  • Docker
  • GoLong的学习之路,进阶,标准库之并发(context)补充并发三部曲,你真的明白context吗?
  • 【深度学习】吴恩达课程笔记(五)——超参数调试、batch norm、Softmax 回归
  • 基于C#实现字符串相似度
  • 【PostgreSQL】日期操作
  • 邦芒支招:求职自荐的五条技巧
  • 如何为视频添加旁白,有哪些操作技巧?
  • [Android]创建TabBar
  • IOS 关于CoreText的笔记
  • idea中误删.iml和.idea文件,如何处理
  • flink 查看写入starrocks的数据量 总行数
  • VivadoAndTcl: synth_ip
  • ASUS华硕ROG幻13笔记本电脑GV301QE原厂Windows10系统
  • 区别Vue 2.0 和 Vue 3.0
  • (六)什么是Vite——热更新时vite、webpack做了什么
  • 让资产权利归于建设者:Kiosk使过程变得更简单
  • BSN专网项目介绍:宁波市区块链新型基础设施“甬链”
  • JS实现拖拽效果(内含源码)
  • 统信UOS通过源码安装软件提示“configure: error: cannot run C compiled programs.”错误
  • Vue2基础-Vue对象进阶介绍1
  • 数字化未来:实时云渲染在智慧城市中的创新应用