两个浏览器窗口间通信总结

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了两个浏览器窗口间通信总结相关的知识,希望对你有一定的参考价值。

参考技术A


一个窗口更新localStorage,另一个窗口监听window对象的”storage”事件,来实现通信。
注:两个页面要同源(URL的协议、域名和端口相同)

所有的WebSocket都监听同一个服务器地址,利用send发送消息,利用onmessage获取消息的变化,不仅能窗口,还能跨浏览器,兼容性最佳,只是需要消耗点服务器资源。

借助iframe 或 window.open
回顾一下API


在页面A设置一个使用 setInterval 定时器不断刷新,检查 Cookies 的值是否发生变化,如果变化就进行刷新的操作。

由于 Cookies 是在同域可读的,所以在页面 B 审核的时候改变 Cookies 的值,页面 A 自然是可以拿到的。

这样做确实可以实现我想要的功能,但是这样的方法相当浪费资源。虽然在这个性能过盛的时代,浪费不浪费也感觉不出来,但是这种实现方案,确实不够优雅。

html5 中的 Web Worker 可以分为两种不同线程类型,一个是专用线程 Dedicated Worker,一个是共享线程 Shared Worker。


其实就是直接获取对方DOM,适用于两个页面在同一域;可以传递对象数据(对象数据使用 instanceof 做类型判断时有坑);参考 window.open;
例:

浏览器窗口有window.name属性。这个属性的最大特点是,无论是否同源,只要在同一个窗口里,前一个网页设置了这个属性,后一个网页可以读取它。

父窗口先打开一个子窗口,载入一个不同源的网页,该网页将信息写入window.name属性。

接着,子窗口跳回一个与主窗口同域的网址。

然后,主窗口就可以读取子窗口的window.name了。

这种方法的优点是,window.name容量很大,可以放置非常长的字符串;缺点是必须监听子窗口window.name属性的变化,影响网页性能。


以上是关于两个浏览器窗口间通信总结的主要内容,如果未能解决你的问题,请参考以下文章

浏览器窗口间通信

C#-MDI-多窗口通信方法总结

08.electron-(渲染进程间的通信)

linux系统进程间通信方式:管道

Unix进程小结进程间通信方式总结

进程间的通信简单总结