广播事件
Socket.IO 使向所有连接的客户端发送事件变得容易。
信息
请注意,广播是仅服务器功能。
给所有连接的客户端
data:image/s3,"s3://crabby-images/d3c4a/d3c4a185a99acc14bb0efb20a6531be94e10d917" alt="Broadcasting to all connected clients"
data:image/s3,"s3://crabby-images/8aa94/8aa94477cc54e2efce55f0d594eec08e36e21d34" alt="Broadcasting to all connected clients"
io.emit("hello", "world");
警告
当前断开连接(或正在重新连接)的客户端将不会收到该事件。将此事件存储在某处(例如在数据库中)取决于您的用例。
除发送者外的所有连接的客户端
data:image/s3,"s3://crabby-images/2bb9a/2bb9a8d19ae90a0dd38bc7cf27f8fe85b568f72b" alt="Broadcasting to all connected clients excepting the sender"
data:image/s3,"s3://crabby-images/bf97c/bf97cef949806def329393037b4fb5b2e6d922ec" alt="Broadcasting to all connected clients excepting the sender"
io.on("connection", (socket) => {
socket.broadcast.emit("hello", "world");
});
备注
在上面的示例中,使用socket.emit("hello", "world")
(不带broadcast
标志)会将事件发送到“客户端 A”。您可以在备忘单中找到发送事件的所有方式的列表。
使用多个 Socket.IO 服务器
广播也适用于多个 Socket.IO 服务器。
您只需将默认适配器替换为Redis 适配器或其他兼容的适配器。
data:image/s3,"s3://crabby-images/6e5e8/6e5e88e0ceb11301b1991c89ce50cbda27250f57" alt="Broadcasting with Redis"
data:image/s3,"s3://crabby-images/00d0e/00d0e2d8ae84b6e083e04c64ec30fb4dfb402a0c" alt="Broadcasting with Redis"
在某些情况下,您可能只想向连接到当前服务器的客户端广播。您可以使用local
标志实现此目的:
io.local.emit("hello", "world");
data:image/s3,"s3://crabby-images/5d3a2/5d3a2f5879072d51d3383a002e9cc6287f8a4d2a" alt="Broadcasting with Redis but local"
data:image/s3,"s3://crabby-images/ebf40/ebf40d959c9f4a9364bdd15693548934def1c1de" alt="Broadcasting with Redis but local"
为了在广播时针对特定客户,请参阅有关Rooms的文档。