【发布时间】:2017-12-01 08:15:49
【问题描述】:
我是 node.js 和 socket.io 的新手,我能够通过 node.js 启动本地服务器并使用 console.log 获取连接到端口 3000 的客户端数量现在我的下一步是在我的 HTML 上显示它,我正在阅读有关如何在 HTML 中包含 socket.io.js 并尝试了 on('connect') 方法,但它返回了一个未定义的错误,任何建议都将提前非常感谢!
我的 server.js
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io').listen(server);
users = [];
connections = [];
server.listen(process.env.PORT || 3000);
console.log('listening to port 3000, server is running..');
app.get('/', function (req,res){
res.sendFile(__dirname + '/index.html');
});
io.sockets.on('connection',function(socket){
connections.push(socket);
console.log('Connected: %s sockets connected', connections.length);
//Disconnect
socket.on('disconnect', function(data){
users.splice(users.indexOf(socket.username), 1);
updateUsernames();
connections.splice(connections.indexOf(socket), 1);
console.log('Disconnected: %s sockets connected', connections.length);
});
});
在我的 index.html 上
//This is located on my html head tag
<script src="http://localhost/socket.io/socket.io.js"></script>
<div class="col-lg-12">
<h1 id="users"></h1>
</div>
<script>
var socket = io.connect('http://localhost:3000');
socket.on('connect',function(){
$('#users').html = socket.users.length;
));
</script>
【问题讨论】: