0

Socket.IOで非常に奇妙な問題が発生しています。何らかの理由で、すべての接続でn + 1の応答が発生するため、送信「バッファ」が何度も複製されているようです。

COM.ping();
undefined
0 "CONNECTION STATUS: OK - 0" app.js:9
COM.ping();
undefined
1 "CONNECTION STATUS: OK - 1" app.js:9
2 "CONNECTION STATUS: OK - 1" app.js:9
COM.ping();
undefined
3 "CONNECTION STATUS: OK - 2" app.js:9
4 "CONNECTION STATUS: OK - 2" app.js:9
5 "CONNECTION STATUS: OK - 2" app.js:9
COM.ping();
undefined
6 "CONNECTION STATUS: OK - 3" app.js:9
7 "CONNECTION STATUS: OK - 3" app.js:9
8 "CONNECTION STATUS: OK - 3" app.js:9
9 "CONNECTION STATUS: OK - 3" app.js:9
COM.ping();
undefined
10 "CONNECTION STATUS: OK - 4" app.js:9
11 "CONNECTION STATUS: OK - 4" app.js:9
12 "CONNECTION STATUS: OK - 4" app.js:9
13 "CONNECTION STATUS: OK - 4" app.js:9
14 "CONNECTION STATUS: OK - 4" app.js:9

このためのコードはかなり単純です。クライアントの場合:

    this.ping = function(){
        socket.on('PING__',function (data){
            console.log(count++,"CONNECTION STATUS: "+$(data)[0].status);
            data = '';
        });
        socket.emit('__PING');
    }

サーバー上:

    var counter = 0;
    io.sockets.on('connection', function (socket) {
        socket.on('__PING', function (data) {
            socket.emit('PING__' , {status:'OK - '+counter++});
        });
    });

それで、どういうわけか、私がpingを試みたとき、それはどういうわけか繰り返しです。理由はわかりません。何か案は?

4

1 に答える 1

1

理解した。本当にばかげた論理エラー:

 this.ping = function(){
        socket.on('PING__',function (data){
            console.log(count++,"CONNECTION STATUS: "+$(data)[0].status);
            data = '';
        });
        socket.emit('__PING');
    }

になるはずだった:

var events = {};
this.ping = function(){
    if(typeof events.ping === 'undefined'){
        events.ping = socket.on('PING__',function (data){
            console.log("CONNECTION STATUS: "+$(data)[0].status);
            data = '';
        });
    }
    socket.emit('__PING');
}

イベントハンドラーを何度もバインドしていたのでめちゃくちゃでした笑。

于 2012-11-26T19:13:31.173 に答える