JavaScript中 判断网络状态的几种方法
  FnV8h0NcFBon 2023年11月13日 21 0


1. 使用 Navigator onLine 属性

Navigator onLine 属性判断浏览器是否在线,在线返回 true,离线返回 false;
Navigator onLine 是只读属性,所有主流浏览器都支持 onLine 属性;

if (window.navigator.onLine) {
  console.log('网络正常!');
} else {
  console.log('网络中断!');
}
2. 使用 ononline、onoffline 事件

这两个方法属于 “侦听器”,在网络连接 / 断开的瞬间会触发(当网络从离线变为在线或从在线变为离线时,分别触发这两个事件)。
注意:检测 ononline 事件,要绑定在 window 对象上;

兼容

不兼容

attachEvent

IE7、IE8

firefox、chrome、IE9、IE10、IE11、safari、opera

addEventListener

firefox、chrome、IE、safari、opera

IE7、IE8

完整代码:

<script type="text/javascript">
  if (window.addEventListener) {  
    window.addEventListener("online", () => {  
      console.log('网络连接恢复');
    }, true);  
    window.addEventListener("offline", () => {  
      console.log('网络连接中断');
    }, true);   
  }else if (window.attachEvent) {  
    window.attachEvent("ononline", () => {  
      console.log('网络连接恢复');
    });  
    window.attachEvent("onoffline", () => {  
      console.log('网络连接中断');
    }); 
  }else {  
    window.ononline = () => {  
      console.log('网络连接恢复');
    };  
    window.onoffline = () => {
      console.log('网络连接中断');
    }; 
  } 
</script>
总结:

为了判断是否离线,在页面加载后,可先通过 navigator.onLine 取得初始的状态,然后通过ononline、onoffline 事件来确定网络连接状态是否变化。
一个缺点:navigator.onLine 和 online、offline事件却不是万能的,只能判断无线和网线是否连接,而不能进一步判断该网络是否能够上网。


【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

推荐阅读
  f18CFixvrKz8   2024年05月20日   90   0   0 JavaScript
  fxrR9b8fJ5Wh   2024年05月17日   52   0   0 JavaScript
  2xk0JyO908yA   2024年04月28日   40   0   0 JavaScript
FnV8h0NcFBon