转到主要内容
版本:4.x

广播

接下来的目标是从服务器向其他用户发送事件。

为了向所有人发送事件,Socket.IO 提供了 io.emit() 方法。

// 这将向所有连接的套接字发送事件
io.emit('hello', 'world');

如果你想向除某个特定发送套接字之外的所有人发送消息,可以使用 broadcast 标志从该套接字发送:

io.on('connection', (socket) => {
socket.broadcast.emit('hi');
});

在这个例子中,为了简单起见,我们将向所有人发送消息,包括发送者。

io.on('connection', (socket) => {
socket.on('chat message', (msg) => {
io.emit('chat message', msg);
});
});

在客户端,当我们捕获到 chat message 事件时,会将其显示在页面中。

<script src="/socket.io/socket.io.js"></script>
<script>
const socket = io();

const form = document.getElementById('form');
const input = document.getElementById('input');
const messages = document.getElementById('messages');

form.addEventListener('submit', (e) => {
e.preventDefault();
if (input.value) {
socket.emit('chat message', input.value);
input.value = '';
}
});

socket.on('chat message', (msg) => {
const item = document.createElement('li');
item.textContent = msg;
messages.appendChild(item);
window.scrollTo(0, document.body.scrollHeight);
});
</script>

让我们看看实际效果:

信息

你可以在浏览器中直接运行这个示例: