We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
在前端,我们经常会用postMessage来实现页面间的通信,但这种方式更像是点对点的通信。对于一些需要广播(让所有页面知道)的消息,用postMessage不是非常自然。Broadcast Channel 就是用来弥补这个缺陷的。
postMessage
顾名思义,Broadcast Channel 会创建一个所有同源页面都可以共享的(广播)频道,因此其中某一个页面发送的消息可以被其他页面监听到。
下面就来速览一下它的使用方法。
Broadcast Channel 的 API 非常简单易用。
首先我们会使用构造函数创建一个实例:
const bc = new BroadcastChannel('alienzhou');
可以接受一个DOMString作为 name,用以标识这个 channel。在其他页面,可以通过传入相同的 name 来使用同一个广播频道。用 MDN 上的话来解释就是:
DOMString
There is one single channel with this name for all browsing contexts with the same origin.
该 name 值可以通过实例的.name属性获得
.name
console.log(bc.name); // alienzhou
Broadcast Channel 创建完成后,就可以在页面监听广播的消息:
bc.onmessage = function(e) { console.log('receive:', e.data); };
对于错误也可以绑定监听:
bc.onmessageerror = function(e) { console.warn('error:', e); };
除了为.onmessage赋值这种方式,也可以使用addEventListener来添加'message'监听。
.onmessage
addEventListener
'message'
Broadcast Channel 实例也有一个对应的postMessage用于发送消息:
bc.postMessage('hello')
可以看到,上述短短几行代码就可以实现多个页面间的广播通信,非常方便。而有时我们希望取消当前页面的广播监听:
close
bc.close();
两者是有区别的:
取消'message'监听只是让页面不对广播消息进行响应,Broadcast Channel 仍然存在;而调用close方法这会切断与 Broadcast Channel 的连接,浏览器才能够尝试回收该对象,因为此时浏览器才会知道用户已经不需要使用广播频道了。
在关闭后调用postMessage会出现如下报错
如果之后又再需要广播,则可以重新创建一个相同 name 的 Broadcast Channel。
可以戳这里查看在线 Demo >>
下面是 Broadcast Channel Demo 的演示效果:
Broadcast Channel 是一个非常好用的多页面消息同步 API,然而兼容性却不是很乐观。
好在我们还有些其他方案可以作为补充(或者作为polyfill),其他的前端跨页面通信可以参考我的另一篇文章《前端跨页面通信的方法》。
The text was updated successfully, but these errors were encountered:
No branches or pull requests
Broadcast Channel 是什么?
在前端,我们经常会用
postMessage
来实现页面间的通信,但这种方式更像是点对点的通信。对于一些需要广播(让所有页面知道)的消息,用postMessage
不是非常自然。Broadcast Channel 就是用来弥补这个缺陷的。顾名思义,Broadcast Channel 会创建一个所有同源页面都可以共享的(广播)频道,因此其中某一个页面发送的消息可以被其他页面监听到。
下面就来速览一下它的使用方法。
如何使用?
Broadcast Channel 的 API 非常简单易用。
创建
首先我们会使用构造函数创建一个实例:
可以接受一个
DOMString
作为 name,用以标识这个 channel。在其他页面,可以通过传入相同的 name 来使用同一个广播频道。用 MDN 上的话来解释就是:该 name 值可以通过实例的
.name
属性获得监听消息
Broadcast Channel 创建完成后,就可以在页面监听广播的消息:
对于错误也可以绑定监听:
发送消息
Broadcast Channel 实例也有一个对应的
postMessage
用于发送消息:关闭
可以看到,上述短短几行代码就可以实现多个页面间的广播通信,非常方便。而有时我们希望取消当前页面的广播监听:
'message'
事件监听close
方法。两者是有区别的:
取消
'message'
监听只是让页面不对广播消息进行响应,Broadcast Channel 仍然存在;而调用close
方法这会切断与 Broadcast Channel 的连接,浏览器才能够尝试回收该对象,因为此时浏览器才会知道用户已经不需要使用广播频道了。在关闭后调用
postMessage
会出现如下报错如果之后又再需要广播,则可以重新创建一个相同 name 的 Broadcast Channel。
Demo 效果
可以戳这里查看在线 Demo >>
下面是 Broadcast Channel Demo 的演示效果:
兼容性如何?
Broadcast Channel 是一个非常好用的多页面消息同步 API,然而兼容性却不是很乐观。
The text was updated successfully, but these errors were encountered: