使用socket.io每隔几秒以编程方式触发一个事件
fire an event programatically every some seconds using socket.io
我的服务器希望每隔一段时间就对客户端说"hi"。我有这个代码示例来演示根据时间间隔触发事件。但遗憾的是,这并没有奏效。
服务器:
var app = require('http').createServer(handler),
io = require('socket.io').listen(app),
fs = require('fs');
app.listen(8001);
function handler(req, res) {
fs.readFile(__dirname + '/client1.html', function(err, data) {
if (err) {
console.log(err);
res.writeHead(500);
return res.end('Error loading client1.html');
}
res.writeHead(200);
res.end(data);
});
}
io.sockets.on('connection', function (socket) {
console.log("runing time");
socket.emit( "clientMessage","hi from server");
socket.on('clientMessage', function () {
socket.emit( "serverMessage","hi from server");
});
socket.on('disconnect', function () {
console.log("disconnecting");
});
});
客户: <script src="/socket.io/socket.io.js"></script>
<script>
var socket = io.connect("http://localhost:8001");
socket.on('connection', function(socket) {
// *this line is not reached*
alert("connected")
sendTestMessage()
socket.on("serverMessage", function(d) {
alert("server Message : " + d)
})
socket.on('disconnect', function() {
alert("disconnected")
});
});
function sendTestMessage() {
alert("test")
socket.emit('clientMessage', "Test Message From Client");
setTimeout(sendTestMessage(), 5000)
}
</script>
我想问题可能在这里:
setTimeout(sendTestMessage(), 5000)
看起来像是在调用函数,但只需要传递一个引用。
试题:
setTimeout(sendTestMessage, 5000);
服务器端和客户端的事件应该相同。你应该试试这个server.js:
io.on('connection', function (socket) {
console.log("runing time");
setInterval(()=>{
socket.emit("clientMessage","hi from server")
}, 1000)
socket.on('disconnect', function () {
console.log("disconnecting");
});
client.js:
socket.on('connect',()=>{console.log('socket connected')});
socket.on('disconnect',()=>{console.log('socket disconnected')});
socket.on('clientMessage', (msg)=>{
console.log('Message From Server: ', msg)
});
这将每隔一秒从服务器发送消息到客户端。
相关文章:
- 以编程方式填充组合框道场 (1.8) 的最佳方法是什么?
- 以编程方式选择文本Mobile Safari
- Thunderbird,如何以编程方式选择第一个选项卡
- 以编程方式获取无线接入点列表
- 使用Javascript/jQuery以编程方式将当前锚点/哈希/片段附加到任何表单操作url
- 通过javascript以编程方式将文件插入HTML输入
- 如何以非编程方式国际化HTML文本
- Y组合器如何以编程方式计算不动点
- 如何以编程方式添加到可变嵌套对象中
- 在视图中渲染多个按钮以编程方式进行本机反应
- 为什么我在以编程方式打开窗口时遇到问题
- 以编程方式添加的复选框的值
- 以编程方式将fabric-js-canvas的图像替换为hq图像,并重新计算其他对象的坐标和大小
- 可以't以编程方式关闭jQuery移动弹出窗口中的可折叠部分
- 以编程方式调用javascript函数
- 如何以编程方式查找javascript语法错误的位置
- 以编程方式将特定的JavaScript添加到Qualtrics中的特定问题中
- 当以编程方式更改输入值时,不会执行更改时事件
- 如何以编程方式在 jsTree 中选择一个节点并打开所有父节点
- 我如何以与使用@ configationproperties相同的方式以编程方式加载yaml文件