关于节点的事情是,所有东西都有模块。 对于所有东西,都有一个“初始提交”,而且很可能在 github 中。对于这种情况,从客户端向服务器发出请求或换句话说进行 RPC 调用是每个应用程序的一部分。这种情况下的基本传输方法是ajax。在一些现代浏览器上,我们有 websockets。对于 ajax,这是您可以制作您想要的东西的最简单方法:
在客户端:
var request.ajax('/ajax/setLolz', {data : 'nice', type : 'post'})
request.done(function(msg) {
$("#lolz").html( msg );
});
在服务器端:
var url = reruire('url')
var http = require('http');
var lolz = 'wow';
var methods = {
'/ajax/setLolz' : function (action, body, res) {
res.end(lolz);
lolz = body;
someOtherFunction();
}
}
http.createServer(function (req, res) {
var body = '';
var action = url.parse(req.url);
req.on('body', function(text) {
body += text;
}
req.on('end', function() {
methods[action.path](action, body, res);
}
}).listen(1337, '127.0.0.1');
这是简单的 ajax。您可以使用connect 让它变得更好:
var connect = require('connect');
var app = connect()
.use(connect.bodyParser())
.use(function(req, res){
var action = url.parse(req.url);
methods[action.path](action, body, res);
})
.listen(1337);
或者更简单的express:
var app = require('express');
var app = express.createServer()
.use(express.bodyParser());
app.get('/ajax/setLolz', function(req, res){
res.end(lolz);
lolz = req.body;
someOtherFunction();
});
app.listen(1337);
是的,有很多 modules 可以帮助您。
就 websockets 而言,我所知道的最快的 websocket 服务器是 ws。虽然有些浏览器可能不支持它。
在客户端:
websocket = new WebSocket('ws://www.host.com/ws');
websocket.onopen = function(evt) {
websocket.send(JSON.stringify({method : 'setLolz', msg : 'yes '};
};
websocket.onmessag = function(evt) {
$("#lolz").html( evt.data );
}
在服务器上:
var WebSocket = require('ws');
var ws = new WebSocket('ws://www.host.com/ws');
var methods = {
'setLolz' : function (msg, ws) {
ws.send(lolz);
lolz = msg;
someOtherFunction();
}
}
ws.on('message', function(data, flags) {
data = JSON.parse(data);
methods[data.method](data.msg);
});
然后是socket.io,它让事情变得更容易。它是跨浏览器,可以在任何地方使用。建立在 ajax 和 websockets 和其他一些方法上。您将所有内容都修补到事件中。您甚至可以在侦听同一端口的 http 服务器旁边使用它。
var io = require('socket.io').listen(1337);
io.sockets.on('connection', function (socket) {
socket.on('setLolz', function(data) {
socket.emit('lolz', lolz);
lolz = data;
});
socket.on('setLolz', someOtherFunction);// Yes, you can listen to an event with two functions
});
但还是不够简单,所以现在给大家介绍nowjs。
在浏览器上:
now.setLolz(function(data){
$("#lolz").html( data );
});
在服务器端:
var nowjs = require("now");
var app = nowjs.initialize(httpServer);
app.now.setLolz = function(cb){
cb(lolz);
lolz = data;
someOtherFunction();
}
我不想更深入,但我希望你明白要点。还有其他模块(dnode、hook.io、flatiron、railwayjs、racer、locomotivejs,...)可以帮助您。是的,您随时可以自己制作。
编码愉快... :D