javascript - 服务器不处理事件 (socket.io/node.js)
我刚刚开始使用 Node.js/Socket.io,想要构建一个示例应用程序,其中:
- 连接时,服务器和客户端都会打印“已连接!”。
- 每次客户端提交消息时,服务器都会打印内容并响应给客户端。
这是我的代码:
NodeJS 0.6.7
Socket.IO 0.8.7
服务器脚本:
var io = require('socket.io').listen(8081);
io.set("log level", 1);
io.sockets.on('connection', function (socket) {
console.log('connected!');
socket.on('sendchat', function (data) {
console.log(data);
socket.emit('updatechat', data);
});
});
客户端脚本:
<script src="http://localhost:8081/socket.io/socket.io.js" type="text/javascript" charset="utf-8"></script>
<div id="main-content">
</div>
<script type="text/javascript" charset="utf-8">
var socket = io.connect('http://localhost:8081');
socket.on('connect', function () {
document.getElementById('main-content').innerHTML = '<p>connected!</p>';
});
socket.on('updatechat', function (data) {
document.getElementById('main-content').innerHTML += '<p>'+data+'</p>';
});
function sendMessageToServer() {
var message = document.chatfrm.content.value;
socket.emit('sendchat', message);
document.chatfrm.content.value = '';
}
</script>
<div id="chat">
<form action="" id="chat-frm" name="chatfrm">
<table>
<tr>
<td><textarea id="content" cols="30" rows="5" name="content"></textarea></td>
</tr>
</table>
<input type="button" value="Post" id="submit" onclick="sendMessageToServer()"/>
</form>
</div>
但是,只有服务器打印“已连接!”当服务器&客户端已连接。此外,当客户端提交消息时,服务器不会按照我的预期记录内容。
感谢您的帮助!
I've just started with Node.js/ Socket.io and want to build an sample app in which:
- When connected, both server and client print 'connected!'.
- Everytime client submit a message, server print content and respond back to client.
Here is my code:
NodeJS 0.6.7
Socket.IO 0.8.7
Server script:
var io = require('socket.io').listen(8081);
io.set("log level", 1);
io.sockets.on('connection', function (socket) {
console.log('connected!');
socket.on('sendchat', function (data) {
console.log(data);
socket.emit('updatechat', data);
});
});
Client script:
<script src="http://localhost:8081/socket.io/socket.io.js" type="text/javascript" charset="utf-8"></script>
<div id="main-content">
</div>
<script type="text/javascript" charset="utf-8">
var socket = io.connect('http://localhost:8081');
socket.on('connect', function () {
document.getElementById('main-content').innerHTML = '<p>connected!</p>';
});
socket.on('updatechat', function (data) {
document.getElementById('main-content').innerHTML += '<p>'+data+'</p>';
});
function sendMessageToServer() {
var message = document.chatfrm.content.value;
socket.emit('sendchat', message);
document.chatfrm.content.value = '';
}
</script>
<div id="chat">
<form action="" id="chat-frm" name="chatfrm">
<table>
<tr>
<td><textarea id="content" cols="30" rows="5" name="content"></textarea></td>
</tr>
</table>
<input type="button" value="Post" id="submit" onclick="sendMessageToServer()"/>
</form>
</div>
However, only server print 'connected!' when server & client are connected. Besides, when client submit message, server doesn't log content as I expected.
Thank for your help!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论