Broadcast Channel API 是浏览器提供的同一源下跨标签页通信方案,通过创建同名频道实例实现消息收发,支持 postMessage 发送和 onmessage 监听,适用于状态同步与操作通知,需注意仅限同源、数据可序列化、不保证消息顺序,且应调用 close() 释放资源。

Broadcast Channel API 是浏览器提供的一种轻量级跨标签页通信方式,允许同一源下的不同页面实例之间发送和接收消息。它使用简单,不需要依赖服务器或复杂的存储机制,适合实现页面间的状态同步、用户操作通知等场景。
要使用 Broadcast Channel API,首先需要创建一个 BroadcastChannel 实例,传入一个通道名称(字符串),所有使用相同名称的频道可以互相通信。
示例代码:
const channel = new BroadcastChannel('my-channel');只要多个标签页都连接到名为 'my-channel' 的频道,它们就能互相收发消息。
假设你有两个页面(或同一个页面打开多个标签),可以通过以下方式实现双向通信:
完整示例:
// page.js在另一个标签页中运行相同代码,即可看到消息互通。
Broadcast Channel 虽然简单易用,但需要注意以下几点:
基本上就这些。对于简单的标签页通信需求,Broadcast Channel API 是最直接的选择,无需引入额外依赖。
以上就是如何用Broadcast Channel API实现标签页通信?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号