如何实现网页多标签tab通讯

本文介绍了在前端开发中实现网页多标签页及iframe之间通讯的几种方法,包括利用localStorage、SharedWorker以及window.postMessage。详细讲解了各自的优缺点和使用场景,如通过localStorage在同域页面间通讯,SharedWorker用于多页面共享通讯,以及window.postMessage实现跨域iframe的通讯。还提供了源码参考和浏览器兼容性的注意事项。
摘要由CSDN通过智能技术生成

例如打开两个 chrome 标签,一个访问列表页,一个访问详情页。在详情页修改了标题,列表页也要同步过来。

使用 webSocket

无跨域限制

需要服务端支持,成本高

通过 localStorage 通讯

同域的 A 和 B 两个页面,可以通过 localStorage 通讯。

A 页面设置 localStorage

B 页面可以监听到 localStorage 值的修改

list 页面

window.addEventListener('storage', event => {
    console.log('key', event.key)
    console.log('newValue', event.newValue)
})

detail 页面

localStorage.setItem('changeInfo', 'xxx')

通过 SharedWorker 通讯

SharedWorker 是 WebWorker 的一种

WebWorker 可开启子进程执行 JS,但不能操作 DOM

SharedWorker 可单独开启一个进程,用于同域页面通讯

Javascript 是单线程的,而且和页面渲染线程互斥。所以,一些计算量大的操作会影响页面渲染。[WebWorker](https://developer.mozilla.or

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值