Broadcast Channel API

Broadcast Channel API 允许在同源的浏览上下文中交换数据

创建广播频道

通过直接调用 BroadcastChannel() 构造函数来创建一个广播频道

需要传递一个字符串参数,代表广播频道的名称

若该名称的广播频道已经创建,则会复用并加入已有的广播频道

1
const bc = new BroadcastChannel('bc')

传递的广播频道名称可以经由 BroadcastChannel 实例的 name 只读属性读取

发送消息

通过调用 BroadcastChannel 实例的 postMessage() 方法来向广播频道发送消息

1
bc.postMessage('message')

发送的消息会经由结构化克隆算法处理,因此任意可由结构化克隆算法处理的类型的数据均可发送

订阅消息

通过监听 BroadcastChannel 实例的 message 事件监听成功接收的消息

1
2
3
bc.addEventListener('message', (e) => {
console.log(e.data)
})

通过监听 BroadcastChannel 实例的 messageerror 事件监听接收失败的消息

1
2
3
bc.addEventListener('messageerror', (e) => {
console.log(e.data)
})

关闭广播频道

通过调用 BroadcastChannel 实例的 close() 方法来断开与广播频道的连接

1
bc.close()

广播频道在没有任一浏览上下文连接至其时被回收

示例

收到的信息为:

类型

1
2
3
4
5
6
7
8
9
10
11
12
interface BroadcastChannel extends EventTarget {
readonly name: string
onmessage: ((this: BroadcastChannel, ev: MessageEvent) => any) | null
onmessageerror: ((this: BroadcastChannel, ev: MessageEvent) => any) | null
close(): void
postMessage(message: any): void
}

declare var BroadcastChannel: {
prototype: BroadcastChannel
new(name: string): BroadcastChannel
}

链接

发布于

2023-11-02

更新于

2025-01-05

许可协议

评论

:D 一言句子获取中...

加载中,最新评论有1分钟缓存...