Node.js - socket disconnect事件不能正常工作
Node.js - socket disconnect event doesn't work properly
在我的Node应用程序中,我使用socket.io
实现websocket功能。
为了让客户端知道服务器何时不可用,我使用以下代码:
socket.on('disconnect', function(){
//show error to client
});
这个很好,但是有一个讨厌的副作用。每次我点击链接离开页面(或者只是重新加载页面),消息就会弹出——因为客户端断开了连接。我当然不希望每次访问者点击链接时都显示"服务器不可用"的消息。
我可以在错误消息上设置一个超时,让浏览器有时间在错误显示之前简单地导航。但你会承认这是一个简陋的解决方案。此外,还会出现两个问题:
1)在需要实际显示错误信息的情况下,错误信息将被超时量延迟,使用户在该时间间隔内无法使用应用程序并且没有通知
2)它不会工作的页面重新加载(我认为)
不管怎样,一定有更好的办法。对吧?
注意:这是Firefox的问题,但不是Chrome。还没有测试过其他浏览器。Firefox还在控制台中显示一条错误消息,指出websocket连接被中断,我倾向于认为这两个问题有一个共同的原因。我读了不少关于这个控制台错误的问题和答案,但似乎没有一个适用于我的情况。
我以前遇到过这种情况。
你想知道用户什么时候离开页面,你不想弹出一个错误。
使用onbeforeunload
在他们离开时发出信号,然后设置一个布尔值,以便套接字。IO不触发错误
window.onbeforeunload = function(){
window.unloading = true;
return; // don't return a string here or it will pop up asking user if they want to navigate away.
}
socket.on('disconnect', function(){
// setTimeout might be optional depending on when onbeforeunload is called
setTimeout(function(){
if (!window.unloading)
//show error to client
}, 10); // 10 ms should be long enough for onbeforeunload, and short enough so your real disconnects don't wait
});
on before unload在用户试图导航离开时被调用。
通常用于调用消息,询问用户是否希望导航离开,但您可以设置一个变量,表示断开连接没有错误。
为什么不尝试在页面导航中注销disconnect处理程序呢?
function alertfun(){
//show error to client
}
socket.on('disconnect', alertfun);
window.onbeforeunload = function(){
socket.removeEventListener('disconnect',alertfun);
}
同一个事件可以有多个监听器。去掉那些你不想要的。您应该尝试这个,因为我不确定disconnect
事件是在onbeforeunload
之前还是之后触发的。
我遇到过这个问题。我做错了什么
<a href="<path>" >Link Name</a>
How I resolve
<a href="<path>" target="_blank">Link Name</a>
我有一个相同的问题,我得到了一些原因,希望这将帮助你。查看此链接
这篇文章解释了:https://stackoverflow.com/a/24009316/3715815。如果你不使用angular/backbone/或类似的单页应用程序方法,你将永远无法导航页面,而不是每次打开带有target=_blank的新页面,从而为每个打开的窗口产生新的连接,或者在每次服务器刷新时不带target=blank连接和断开与新的套接字实例的连接。
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- JS可以在Chrome中工作,但不能在Firefox中工作
- ajaxToolkit PopupControlExtender不工作.过时的
- HTML标记在脚本标记中工作
- javascript扫雷器floodfill算法不能正常工作