javascript - socket.io和express js的使用

标签 javascript node.js sockets

我是Node js的新手,刚刚通过socket.io和express 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 之间有一些关系,谁能解释一下这两者的关系和用法。

这将帮助我进一步进入更多的 node js 应用程序

谢谢!

最佳答案

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

关于javascript - socket.io和express js的使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18511149/

相关文章:

javascript - 如何使用jquery向下滚动到底部子div

javascript - 用户在文本区域输入的字符数超过最大长度时出现错误消息

python - 如何在 Python 套接字应用程序中接受 GET 请求?

javascript - 让gulp在处理后的scss文件所在的目录下动态写入css

node.js - 从nodejs调用rabbitmq

ruby-on-rails - 实时聊天应用程序使用什么

javascript - 如何在模块中填充集合以在事件/命令内使用

c# - 在套接字读取之前替代 Thread.Sleep()

c - 'SO_USELOOPBACK' 未在此范围内声明

大型项目中使用 jquery 等的 JavaScript 乱码?