浏览器内多个标签页之间的通信方式有哪些?

传递方式

1.WebSocket (可跨域)

WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。

2.postMessage(可跨域)

window.postMessage()方法安全地启用Window对象之间的跨源通信。

对将接收消息的窗口的引用,获得此类引用的方法包括:


1.iframe标签

2.Window.open (生成一个新窗口然后引用它)

3.Window.opener (引用产生这个的窗口)

3.SharedWorker

4.Server-Sent Events

以上的传递方法仅供了解几乎很少使用到

5.localStorage(可以添加事件监听)

localstorage是浏览器多个标签共用的存储空间,所以可以用来实现多标签之间的通信(ps:session是会话级的存储空间,每个标签页都是单独的)。 直接在window对象上添加监听即

​
//在同源的两个页面中,可以监听 storage 事件
            window.addEventListener("storage", function (e) {
                alert(e.newValue);
            });

​
//在同一个页面中,对 localStorage 的 setItem 方法进行重写
            var orignalSetItem = localStorage.setItem;
            localStorage.setItem = function(key,newValue){
                    var setItemEvent = new Event("setItemEvent");
                    setItemEvent.newValue = newValue;
                    window.dispatchEvent(setItemEvent);
                    orignalSetItem.apply(this,arguments);
            }
            window.addEventListener("setItemEvent", function (e) {
                alert(e.newValue);
            });
            localStorage.setItem("name","wang");
            });
            

6.Cookies

Cookies在同一个域名内,并且目录也得相同,可以参考第三方库

cookies详情

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值