繁体   English   中英

socket.io 房间不工作

[英]socket.io rooms don't work

我是 node js 上的 socket.io,我的目标是将创建房间和加入房间事件发送到服务器,然后广播给加入房间的人。 我成功地创建了我认为的房间,但是当我使用.to()发送任何内容时,它不起作用。

索引.html

<html>

<head>
    <script src="/socket.io/socket.io.js"></script>
</head>

<body>
    <label for="joinRoom"> Join room</label>
    <form id="joinRoom">
        <input id="room" /><button>Send</button>
    </form>
    <label for="createRoom"> Create room</label>
    <form id="createRoom">
        <input id="players" /><button>Send</button>
    </form>
    <script src="/client.js"></script>
</body>

</html>

客户端.js

const socket = io();

socket.on('test', (data) => console.log(data));

document.getElementById('joinRoom').onsubmit = () => {
    socket.emit('joinRoom', document.getElementById('room').val());
    return false;
};

socket.on('roomCreated', (id) => {
    console.log(id);
    //
});

document.getElementById('createRoom').onsubmit = () => {
    socket.emit('createRoom', document.getElementById('players').value);
    return false;
};

服务器.js

const express = require('express');
const app = express();
const server = require('http').createServer(app);
const io = require('socket.io').listen(server);

app.use(express.static('public'));

server.listen(3000, () => {
    console.log('listening...');
});

let currentRoomID = 0;
const rooms = [];

io.on('connection', (socket) => {
    function joinRoom(room) {
        socket.join(room.toString());
    }
    socket.on('createRoom', () => {
        const roomID = currentRoomID++;
        rooms[roomID] = `foo ${roomID}`;
        joinRoom(roomID, socket.id);
        io.sockets.emit('roomCreated', roomID);
        socket.to(roomID.toString()).emit('test', rooms[roomID]);
    });
    socket.on('joinRoom', (room) => {
        joinRoom(room, socket.id);
    });
});

如果您想向特定房间中的人发送特定消息,请执行以下操作:

io.sockets.in(room).emit('something', something);

或者,如果您想向特定套接字发出某些内容,您可以执行以下操作:

io.to(socket).emit('something', something);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM