socket.io和express js的用法

时间:2013-08-29 12:33:47

标签: javascript node.js sockets

我是Node js的新手,刚才我通过socket.io遇到并表达了js,我想知道它们之间的区别或它们之间的关系。我有一些用于聊天应用程序的小代码

在nodeClient.js

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

$( "#messageForm" ).submit( function() {

var nameVal = $( "#nameInput" ).val();
var msg = $( "#messageInput" ).val();
alert("msg");
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();
alert(actualContent);
var newMsgContent = '<li> <strong>' + data.name + '</strong> : ' + data.message + '</li>';
var content = newMsgContent + actualContent;

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

并在nodeServer.js

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 } );
        io.sockets.emit( 'message', { name: data.name, message: data.message } );
    });
});

server.listen( 8080 );

现在,来到我怀疑的地方

在nodeServer.js文件中,我有

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

var io = socket.listen( server );

我可以观察到socket和express之间存在某种关系,有谁能请解释一下这两者的关系和用法。

这将帮助我进一步了解更多节点js应用程序

谢谢!

1 个答案:

答案 0 :(得分:0)

在nodeServer.js中,您可以声明或调用socket.io或express。在nodeClient.js中。您将运行这些功能。我可以说,使用socket.io,我们从数据库中获取数据,它将与它一起存储,并在页面加载时甚至在PHP加载之前显示。所以,我们可以更快地调用nodejs。