Node.js - 套接字断开事件无法正常工作

时间:2014-06-04 14:56:52

标签: javascript node.js sockets

在我的Node应用程序中,我使用socket.io来表示websocket功能。

为了让客户知道服务器何时不可用,我使用以下代码:

socket.on('disconnect', function(){
        //show error to client
    });

这很好,但是有一个令人讨厌的副作用。每次我单击链接导航离开页面(或只是重新加载页面)时,弹出的消息 - 因为客户端断开连接。我当然不希望显示一条消息,说服务器不可用'每次访问者点击链接时。

我可以在错误消息上设置超时,让浏览器有时间在错误显示之前简单地导航。但是你承认这是一个破旧的解决方案。此外,还有两个问题:

1)在需要实际显示的情况下,错误消息将被超时量延迟,使用户无法正常运行,并且在该时间间隔内没有通知

2)它不适用于页面重新加载(我认为)

无论如何,必须有更好的方法。正确?

注意:这是Firefox中的问题,但不是Chrome。 Haven尚未测试其他浏览器。 Firefox还在控制台中显示一条错误消息,指出websocket连接被中断,我倾向于认为这两个问题有一个共同的原因。我已经阅读了很多有关此控制台错误的问题和答案,但似乎没有一个适用于我的情况。

4 个答案:

答案 0 :(得分:1)

我之前遇到过这个问题。

您想知道用户何时离开该页面,并且您不想弹出错误。

使用onbeforeunload指示它们何时离开,然后只需设置一个布尔值,以便socket.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
});
当用户试图离开时,在调用unload之前

on。

通常它用于调用询问用户是否希望离开的消息,但您可以设置一个变量,表明断开连接没有错误。

答案 1 :(得分:1)

为什么不尝试在页面导航中取消注册断开处理程序。

function alertfun(){
    //show error to client
}
socket.on('disconnect', alertfun);

window.onbeforeunload = function(){
    socket.removeEventListener('disconnect',alertfun);
}

您可以为同一个活动提供多个听众。删除你不想要的。您应该尝试这一点,因为我不确定在disconnect之前或之后是否触发onbeforeunload事件。

答案 2 :(得分:0)

我遇到过这个问题。 我做错了什么

<a href="<path>" >Link Name</a>

我如何解决

<a href="<path>" target="_blank">Link Name</a>

我有同样的疑问,我有一些理由,希望这会对你有帮助。请检查此link

答案 3 :(得分:0)

这篇文章解释了它:https://stackoverflow.com/a/24009316/3715815。如果您不使用使用angular / backbone /或类似的单页应用程序方法,则无法在每次都不打开带有target = _blank的新页面的情况下导航页面,从而为每个打开的窗口生成新连接,或者连接和断开与每个服务器上的新套接字实例刷新没有target = blank这是真实的故事,你没有任何魔术技巧。