2014-10-08 45 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>中。