Socket.io和Nodejs:向多个客户端发送响应并更改未保存(?)

时间:2016-02-29 16:02:56

标签: javascript node.js sockets server client-server

编辑:我的第一个问题已经解决(相当简单)。第二个问题仍然有效,对于这个问题,我不知道如何解决问题。

我正在进行多人数独游戏。我是Nodejs和socket的新手,所以如果我的想法是错误的,请纠正我。

这是一项正在进行中的工作,而这正是我目前要做的事情:当用户将一个值输入其中一个单元格时,它会使用索引发出一个请求(?)那个单元到服务器。然后,服务器从其拥有的答案表中找到正确的答案,并将结果发送回客户端。然后javascript代码跟进,如果输入了正确的输入,它将为所有用户提供该答案(注意:我假设用户正在输入正确的答案现在;我将在错误的答案部分工作之后)。

问题:

1)现在,正确的答案将锁定在单元格中提交正确答案的人,但不会显示给所有客户。

2)如果我向另一个单元格提交答案(无论是否正确),它将删除过去的更改 - 即用户之前输入的单元格,并且已成为"锁定在"

这是我的javascript代码:

function closeCellInput($cell) {
    var index     = $boardCells.index($cell);
    // var target    = findTarget(index); //SHOULD BE SERVER
    socket.emit('target', index);
    socket.on('targetResult', function(data){
        console.log('data: ' + data);
        var target = data;
        var number    = $cell.find('input').val();
        var complete  = false;

        $cell.empty().removeClass('empty').removeClass('solved').attr('style', null);
        socket.emit('index', index);

        if (number == target) {
            $cell.text(number).addClass('solved');
            complete = true;
            socket.emit('solved', number);

            //complete = checkComplete();
        }
        else if (number != '') {
            var cell      = $cell[0];
            var animator  = new Animator({duration:750});
            var animation = new ColorStyleSubject(cell, "background-color", "#FF8888", "#FFFFFF");

            $cell.text('').addClass('empty');
            animator.addSubject(animation).play();
            //$cell.html('<input type="text"/>').find('input').focus();
            //adding above line does not make the red light blinkerino
        }
        else {
            $cell.text('').addClass('empty');
        }

        $selected = $([]);
    });




}

这是我的相关服务器代码(如果需要):

io.on('connection', function(socket){
    console.log('a user connected');

    socket.on('disconnect', function(){
        console.log('user disconnected');
    });

    socket.on('solved', function(val){
        console.log('number value: ' + val)
    });

    socket.on('target', function(index){
        //Hard coded answers for now, but will be changed later
        var solution = "435269781682571493197834562826195347374682915951743628519326874248957136763418259";

        console.log('index: ' + solution[index]);
        socket.emit('targetResult', solution[index]);

    });

});

提前致谢!!!

1 个答案:

答案 0 :(得分:2)

在您的代码服务器中:

socket.on('target', function(index){
    //Hard coded answers for now, but will be changed later
    var solution = "435269781682571493197834562826195347374682915951743628519326874248957136763418259";

    console.log('index: ' + solution[index]);
    socket.emit('targetResult', solution[index]);

});

只发送到发件人所连接的套接字。为了向所有人发射,请使用以下语法:

socket.on('target', function(index){
    //Hard coded answers for now, but will be changed later
    var solution = "435269781682571493197834562826195347374682915951743628519326874248957136763418259";

    console.log('index: ' + solution[index]);
    io.sockets.emit('targetResult', solution[index]);

});

请注意,我已将socket.emit更改为io.sockets.emit。这使得socket.io广播到所有连接的套接字。

正如Sean Ryan所提到的,如果你想只播放连接到同一游戏的玩家,socket.io文档会有一个关于不同房间的部分:http://socket.io/docs/rooms-and-namespaces/