socket.io无法正常用于广播应用程序

时间:2014-03-21 08:28:46

标签: javascript node.js sockets express socket.io

我正在使用此代码进行简单的广播。

服务器端

var socket = require( 'socket.io' );
var express = require( 'express' );
var http = require( 'http' );

var app = express();
var server = http.createServer( app );

var io = socket.listen( server );

io.sockets.on( 'connection', function( client ) {
console.log( "New client !" );

client.on( 'message', function( data ) {
    console.log( 'Message received ' + data.name + ":" + data.message );

    client.broadcast.emit( 'message', { name: data.name, message: data.message } );
    client.emit( 'message', { name: data.name, message: data.message } );
});
});

server.listen( 16558 );

对于客户端,我使用此代码发送和接收来自其他在线用户的消息 客户机侧

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

$( "#messageForm" ).submit( function() {
var nameVal = $( "#nameInput" ).val();
var msg = $( "#messageInput" ).val();

socket.emit( 'message', { name: nameVal, message: msg } );

// Ajax call for saving datas
$.ajax({
    url: "./ajax/insertNewMessage.php",
    type: "POST",
    data: { name: nameVal, message: msg },
    success: function(data) {

    }
});

return false;
});

socket.on( 'message', function( data ) {
    var actualContent = $( "#messages" ).html();
var newMsgContent = '<li> <strong>' + data.name + '</strong> : ' + data.message + '</li>';
var content = newMsgContent + actualContent;

$( "#messages" ).html( content );
});

socket.emit在客户端不起作用。

添加新客户时&#34;新客户&#34;在控制台上显示,但当任何用户发送消息时,它不会显示在控制台上

我没有收到错误,但邮件没有播出。 任何人都可以帮我解决这个问题。 我可以使用任何其他事件或方法,因为它看起来像发光不能正常工作

1 个答案:

答案 0 :(得分:0)

而不是使用

socket.emit( 'message', { name: nameVal, message: msg } );

试试这个

socket.emit( 'message', nameVal, msg  );