Broadcast Channel API 是浏览器提供的同源跨标签页通信方案,通过创建命名频道实现消息广播;支持 postMessage 发送消息和 onmessage 或 addEventListener 接收消息,适用于登录状态同步、数据共享等场景;需注意仅同源通信、不保证消息顺序与送达、需手动关闭通道,且 IE 不支持、老版 Safari 有限兼容。

Broadcast Channel API 是浏览器提供的一种简单直接的跨标签页通信方式。它允许你在同一个源(origin)下的不同浏览器标签页、窗口或 iframe 之间发送和接收消息。相比其他方法如 localStorage + storage 事件或 postMessage,Broadcast Channel 更直观、语义更清晰。
Broadcast Channel 是一个浏览器 API,用于在同源的不同执行上下文中广播消息。只要页面属于同一个协议、域名和端口,它们就可以通过频道名称建立通信。
每个频道是一个命名的通道,任何加入该频道的页面都可以发送和接收消息。
创建一个 BroadcastChannel 实例非常简单,只需要传入一个频道名称:
立即学习“Java免费学习笔记(深入)”;
const channel = new BroadcastChannel('my-channel');
之后就可以通过 postMessage 发送消息,通过 onmessage 接收消息:
// 发送消息
channel.postMessage('Hello from tab 1!');
// 接收消息
channel.onmessage = function(event) {
console.log('收到消息:', event.data);
};
你也可以使用 addEventListener 的方式监听消息,这种方式更灵活:
channel.addEventListener('message', function(event) {
console.log('接收到:', event.data);
PhpEIP企业信息化平台主要解决企业各类信息的集成,能把各种应用系统(如内容管理系统,网上商城,论坛系统等)统一到企业信息化平台中,整个系统采用简单易用的模板引擎,可自定义XML标签,系统采用开放式模块开发,符合开发接口的模块可完全嵌入到平台;内容管理模块可自定义内容模型,系统自带普通文章模型和图片集模型,用户可以定义丰富的栏目构建企业门户,全站可生成静态页面,提供良好的搜索引擎优化;会员管理模
0
});
这种通信方式特别适合以下场景:
例如,当用户在标签页 A 中退出登录,你可以这样通知其他页面:
const authChannel = new BroadcastChannel('auth');
authChannel.postMessage({ type: 'logout' });
在其他页面中监听:
authChannel.onmessage = function(event) {
if (event.data.type === 'logout') {
// 清除本地状态,跳转到登录页
clearAuth();
window.location.href = '/login';
}
};
虽然 Broadcast Channel 使用方便,但仍有几点需要注意:
如果需要兼容旧浏览器,可以结合 localStorage 监听作为降级方案。
基本上就这些。Broadcast Channel 简单有效,适合大多数跨标签通信需求。以上就是跨标签页通信JavaScript_Broadcast Channel的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号