4

最初のクリックで、私のクライアントはこれを出力します:

Object {hello: "world"} 

次に、2回目のクリックで:

Object {hello: "world"}
Object {hello: "world"} 

また、1 回のクリックで行が出力される回数は、2 回目以降のクリックで 1 回増えます。

クライアント

var socket = io.connect('http://localhost');

$(document).on('click' , '#test', function(){
    socket.emit('news', { my: 'data' });
    socket.on('news', function (data) {
        console.log(data);
    });
});

サーバ

var app = require('http').createServer(handler)
, io = require('socket.io').listen(app)
, fs = require('fs')

io.sockets.on('connection', function (socket) {
socket.on('news', function (data) {
    socket.emit('news', { hello: 'world' });
    console.log(data);
});
});
4

1 に答える 1

4

クリック イベント ハンドラーがトリガーされるたびに、新しいイベント ハンドラーをバインドしています。コールバックの外で 1 回バインドします。

var socket = io.connect('http://localhost');

socket.on('news', function(data) {
    console.log(data);
});

$(document).on('click', '#test', function() {
    socket.emit('news', {
        my: 'data'
    });
});
于 2013-08-11T17:08:55.230 に答える