2014-10-08 47 views
13

所以我最终决定给Node.js一个镜头。我决定与一个小型聊天应用程序打破冰面。我正在遵循的教程直接来自socket.io站点。Socket.io聊天教程无法正常工作

http://socket.io/get-started/chat/

我下面的字教程词,甚至试图将代码复制并粘贴到源和我越来越没有在那里,当我键入文本并发送。它应该在我的命令提示符中出现,但事实并非如此。

我有用户连接和用户断开连接的消息出现,但我难住这一个,因为我一步一步地按照教程。

Index.js

var app = require('express')(); 
var http = require('http').Server(app); 
var io = require('socket.io')(http); 

app.get('/', function(req, res) { 
    res.sendFile('/chat/index.html'); 
}); 

io.on('connection', function(socket){ 
    socket.on('chat message', function(msg){ 
     console.log('message: ' + msg); 
    }); 
}); 

http.listen(3000, function() { 
    console.log('Listening on *:3000'); 
}); 

的Index.html:

<!DOCTYPE html> 
<html> 
<head lang="en"> 
    <meta charset="UTF-8"> 
    <title>Chat</title> 

    <script src="/socket.io/socket.io.js"></script> 
    <script src="http://code.jquery.com/jquery-1.11.1.js"></script> 
    <script> 
     var socket = io(); 
     $('form').submit(function(){ 
      socket.emit('chat message', $('#m').val()); 
      $('#m').val(''); 
      return false; 
     }); 
    </script> 

    <style> 
     * { margin: 0; padding: 0; box-sizing: border-box; } 
     body { font: 13px Helvetica, Arial; } 
     form { background: #000; padding: 3px; position: fixed; bottom: 0; width: 100%; } 
     form input { border: 0; padding: 10px; width: 90%; margin-right: .5%; } 
     form button { width: 9%; background: rgb(130, 224, 255); border: none; padding: 10px; } 
     #messages { list-style-type: none; margin: 0; padding: 0; } 
     #messages li { padding: 5px 10px; } 
     #messages li:nth-child(odd) { background: #eee; } 
    </style> 
</head> 
<body> 

    <ul id="messages"></ul> 

    <form action=""> 
     <input id="m" autocomplete="off" /><button>Send</button> 
    </form> 

</body> 
</html> 

我假设我犯规了一些地方,但我没有看到它,即使我曾尝试复制和粘贴。另外,如果有问题,我正在使用Windows 8.1和Chrome。我查了一下,也发现这个问题没有答案。任何帮助都会很棒。

编辑:问题是与jQuery,由于某些原因它没有响应,因为它应该。在重写香草脚本后,它按预期工作。

Index.js - JavaScript的

<script> 
    var socket = io(); 

    function sendMessage() { 
     var msg = document.getElementById('m'); 

     socket.emit('message', msg.value); 
     msg.value = ''; 
     return false; 
    } 
</script> 

HTML:

<form action="" onsubmit="javascript:sendMessage();"> 
     <input id="m" autocomplete="off" /><button>Send</button> 
</form> 
+0

您可以提供任何服务器和客户端控制台输出吗? – jmar777 2014-10-08 15:46:44

+0

任何一方都没有错误。这就是我发现令人沮丧的。 – 2014-10-08 16:01:57

回答

14

您可以通过在控制台输入激活日志记录Socket.IO在Chrome:

localStorage.debug = "socket.io-client:socket" 

和服务器端:

DEBUG=* node yourfile.js 

此外,要被执行的脚本时准备好文档,以便所以你需要推迟了一点使用jQuery:

$(document).ready(function() { 
    var socket = io(); 
    $('form').submit(function(){ 
     socket.emit('chat message', $('#m').val()); 
     $('#m').val(''); 
     return false; 
    }); 
}); 
+0

我只得到“socket.io-client:套接字传输是开放的 - 连接+ 0ms”。没有其他的。所有这些都在本地主机上运行。 – 2014-10-08 16:35:18

+0

服务器端呢? – xShirase 2014-10-08 16:36:40

+0

“break in index.js:1” – 2014-10-08 16:43:40

6

事后一点点,但是我有同样的问题,并将其绑回加载订单问题。只需将绑定到表单的代码移动到<body>的底部,而不是<head>。这有点误导,因为本教程中的一些早期代码直接在<head>中。