1、方法一
localStorage
发送端设置localstorage值
window.localStorage.setItem('msg', JSON.stringify(data));
接收端监听storage变化
window.addEventListener('storage', function(data) {
console.log(data);
});
优点
1、兼容性强;
2、方法简单;
3、发送信息的窗口不会触发监听事件;
4、可以时间祖孙之间的数据传输;
缺点
1、必须同域,不可跨域;
2、数据大小有限制,与localStorage有关,不同的浏览器不一样,一般5M;
3、数据安全性地;
4、只有数据改变了才能监听到;
5、存储数据类型只能是字符串,引用类型会转化为相应的数据类型,比如对象存储的是[object Object];
方法二
SharedWorker
sharedWorker.js 中央转发类
共享线程,同源策略下,多个运行环境共用同一个线程,包括数据。
// 收集每一个端口
let ports = [];
this.onconnect = function (e) {
let port = e.ports[0];
port.start();
ports.push(port);
// 监听并分发数据
port.addEventListener('message', function(e) {
for (let p of ports) {
p.postMessage(e.data);
}
});
}
发送端
let worker = new SharedWorker('sharedWorker.js');
worker.port.start();
let data = {
id: Math.random()
}
worker.port.postMessage(data);
接收端
let worker = new SharedWorker('sharedWorker.js');
worker.port.start();
worker.port.onmessage = function (val) {
console.log(val)
}
优点
1、对数据类型传输没有限制;
2、可祖孙之间传递数据;
缺点:
1、兼容性低,与worker类似;
2、编写有点困难;
方法三
postMessage
这种需要打开一个页面或通过iframe,常用于iframe中使用;
发送端
<iframe id="iframe" src="./iframe1.html" ></iframe> document.getElementById('iframe').contentWindow.postMessage({msg: 'MessageFromIndexPage'},'\*');
接受端
window.addEventListener('message', function(e) {
console.log(11111)
});
优点
1、可跨域传递数据;
2、对数据类型传输无限制;
缺点:
1、发送窗口也能监听到;
2、只能父子间传递;
3、只能旧的窗口发送信息,新窗口接受信息;不可反过来;
方法四
webSocket
需要有后端服务支持,比如node.js
let ws = new WebSocket('ws://xxxx');
ws.send('发送信息');
接受端
ws.onmessage = function(event) {
console.log(event);
}
优点:
1、可跨端使用;
2、后端可以控制是否对哪一个设备发送消息;
缺点:
1、需要前后端需要一直保持通讯;