Javascript 使basic socket.io示例正常工作

Javascript 使basic socket.io示例正常工作,javascript,node.js,socket.io,Javascript,Node.js,Socket.io,我甚至无法运行非常基本的socket.io示例。例如,他们网站欢迎页面上的第一个示例: var io = require('socket.io').listen(80); io.sockets.on('connection', function (socket) { socket.emit('news', { hello: 'world' }); socket.on('my other event', function (data) { console.log(data);

我甚至无法运行非常基本的socket.io示例。例如,他们网站欢迎页面上的第一个示例:

var io = require('socket.io').listen(80);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});
在服务器端和

<script src="/socket.io/socket.io.js"></script>
<script>
  var socket = io.connect('http://localhost');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>
这已经不是人们所期望的了。然后,对于
client.htm
(或者至少我认为我应该使用它——将它粘贴到client.htm文件中),我只得到一个空白屏幕。这并不奇怪,因为它首先包含一个不存在的文件
/socket.io/socket.io.js
,但即使将其更改为
host.js
(我认为应该是这样),也不会改变我只得到一个空白屏幕的事实


我不知道。

EADDRINUSE表示地址已经在使用中,因此无法获取套接字。您的计算机上的端口80上是否已运行其他程序?web服务器通常使用80

您也可以在其他端口上尝试

您看到空白文件的原因是它没有连接到节点服务器(因为它无法获取套接字),因此不会调用on news事件。它甚至可能连接到80上运行的任何其他设备的套接字,这些设备将永远不会发出该事件:)

解决端口冲突后,在运行服务器时,它应该只说:

信息-socket.io已启动

现在它正在等待连接

确保将htm行更新到您的端口。例如,如果81:

var socket = io.connect('http://localhost:81'); // note the :81
编辑: 我只是尝试了一下,在htm文件中,我必须设置socket.io.js文件的相对路径。通过npm安装后,它就在我的目录中

<script src="node_modules/socket.io/node_modules/socket.io-client/dist/socket.io.js"></script>
赢: dir socket.io.js/s

您还应该运行主机(在*nix上,您可能需要前面的sudo):

我在尝试该示例时做的最后一件事是将htm文件中的几行更改为此,以便在事件发生时可以看到一个警报消息框:

socket.on('news', function (data) {
   alert(JSON.stringify(data));

什么港口重要吗?我尝试了81,但现在它在运行主机端时挂起,也就是说,它说
info-socket.io已启动
,但它没有返回到命令行。.htm页面仍然为空,因此这似乎无法解决问题。它解决了您的第一个问题EADDRINUSE错误。是的,这很重要。它也没有挂起-服务器正在运行,等待通信。现在,您已经解决了服务器端问题的一半。对于问题的客户端,您是否更新了要连接到的htm页面(而不是:81)?我转到了该url,但我机器上的“localhost”不是您运行节点服务器的机器。localhost是我的机器。啊,所以它必须是而不是。我已经想知道客户端如何正确解决本地主机问题。很好,现在可以了,非常感谢!
find . -name 'socket.io.js'
node host.js
socket.on('news', function (data) {
   alert(JSON.stringify(data));