sia*_*sia 2 requirements push long-polling node.js
我是NodeJS的新手(使用c9.io)并且最近对它有了这种厌恶的迷恋.
我想在使用NodeJS时知道.是否可以流式传输基本html页面的内容,而不是大型,而不是特殊的10个并发用户.但是,如果对该html页面进行了更改,用户将立即看到更改.这可以基于任何事件,但基本上基于正在更新的文件内容.我真的希望创建一些简单的原型来给老板留下深刻的印象并用NodeJS来做,希望能够获得我们目前过时使用的setInterval ajax帖子.呕吐
谢谢
好的,这是一个非常简单的例子.textarea与登录成员同步.
请安装http,socket.io和express(ver3).
sudo npm install http, socket.io, express
Run Code Online (Sandbox Code Playgroud)
并创建一个javascript文件.
server.js
var app = require('express')(),
server = require('http').createServer(app),
io = require('socket.io').listen(server),
member_sockets = {},
key;
server.listen(80);
app.get('/', function (req, res) {
res.sendfile(__dirname + '/index.html');
});
io.sockets.on('connection', function (socket) {
var user_id = socket.id;
member_sockets[user_id] = socket;
console.log("[login]-->", user_id);
socket.on('txt_change', function (data) {
for (key in member_sockets) {
if (key != user_id) {
member_sockets[key].emit("txt_change", data);
}
};
});
socket.on('disconnect', function (socket) {
console.log("[logout]-->", user_id);
delete member_sockets[user_id];
});
});
Run Code Online (Sandbox Code Playgroud)
在同一目录中,您还可以创建index.html文件.
的index.html
<!DOCTYPE html>
<html>
<head>
<script src="http://code.jquery.com/jquery-1.8.2.min.js"></script>
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://localhost');
socket.on('txt_change', function (data) {
console.log(data);
$("#txt").val(data.txt);
});
$(document).ready(function(){
$("#txt").keyup(function(){
socket.emit('txt_change', { "txt" : $(this).val() });
});
});
</script>
</head>
<body>
<textarea id="txt" style="width:200px;height:100px"></textarea>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
然后使用以下命令运行服务器:
sudo node server.js
Run Code Online (Sandbox Code Playgroud)
所以代码应该像这张图片一样工作:

| 归档时间: |
|
| 查看次数: |
2814 次 |
| 最近记录: |