2011-09-20 67 views
7

我正忙于使用socket.io和node.js,并想知道如何完成以下操作:我有一个简单的表单,它向文件服务器发送文本字符串,服务器将其发回,并将其附加到div。我想要做的是为所有浏览器中的所有用户更新div,目前它只更新发送消息的那个。从app.js将消息发送到所有带有套接字的浏览器io

代码(Node.js的服务器):

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js" type="text/javascript"></script> 
    <script src="/socket.io/socket.io.js"></script> 
    <script> 
    $(document).ready(function() { 
    var socket = io.connect('http://localhost:3000'); 

    $('#sender').live('click',function() { 
      var user_message = $('#message_box').val() 
      socket.emit('send_message',{message: user_message}); 
    }); 

    socket.on('get_message', function(data) { 
     $('#data').append(data.message); 
     }); 
    }); 
</script> 

和HTML:在客户端

io.sockets.on('connection', function(socket) { 
    socket.on('send_message', function(data) { 
    data.message = data.message + ' yo<br/>'; 
    socket.emit('get_message',data); 
    }); 
}); 

代码

<div id='data'></div> 
<input type='text' id='message_box' placeholder='send message'> 
<button id='sender'>Send Message</button> 

我应该怎么正在做什么来发送消息到多个浏览器?

回答

23

变化

socket.emit('get_message',data); 

socket.broadcast.emit('get_message',data); 

要将其广播到所有连接的用户,除非你在哪里调用播放的插座。

如果您还希望包括插座,你可以做

io.sockets.emit('get_message', data); 
相关问题