我创建了一个基本的 node.js 服务器程序并使用 socket.io 从客户端传递一些字段数据(见下文)。很高兴,因为我是这个行业的新手。我喜欢这种 node-express-socket.io 方法,因为它全部是 Javascript,并且显然可以被大多数浏览器(包括移动设备)使用。问题是我有点摸索,并没有完全理解我创造了什么!两个问题...
1)我需要使用“//ajax.googleapis.com...jquery...”吗?这很烦人,因为浏览器需要有互联网连接才能工作。是否有另一种无需互联网连接即可访问 html 文档元素的方法?
2) "app.use(express.static...." 行是做什么的?"app.get..." 功能似乎需要它才能工作。
如果对我的代码有任何其他一般性评论,请告诉我!
干杯,
柯布斯
客户端代码:
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect(document.location.protocol+'//'+document.location.host);
function clicked(){
$(function(){
var makeInput=$('.app').find('#make').val();
var modelInput=$('.app').find('#model').val();
socket.emit('make', makeInput);
socket.emit('model', modelInput);
});
};
</script>
服务器端代码:
var express = require('express');
var http = require('http');
var socketio = require('socket.io');
var app = express();
var server = http.createServer(app);
var io = socketio.listen(server);
app.use(express.static(__dirname));
app.get('/', function (req, res) {
res.render(__dirname + '/index.html');
});
io.sockets.on('connection', function (socket) {
socket.on('make', function (make) {
socket.on('model',function (model){
console.log('recieved message:', make+','+model);
});
});
});
server.listen(8000);