• JavaScript中 判断网络状态的几种方法


    1. 使用 Navigator onLine 属性

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

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

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

    兼容不兼容
    attachEventIE7、IE8firefox、chrome、IE9、IE10、IE11、safari、opera
    addEventListenerfirefox、chrome、IE、safari、operaIE7、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> 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    总结:

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

  • 相关阅读:
    怎么查看摄像头的ip地址
    VR、AR、MR、XR到底都是什么?有什么区别
    stm32f4xx-USART串口
    boundary IoU 的计算方式
    Python实现模块热加载
    Redis 常用命令的学习
    linux 应用层调用shell指令api.之popen 和system
    Python高校学生档案管理系统毕业设计源码071528
    Jenkins 中配置 LDAP
    作业-11.29
  • 原文地址:https://blog.csdn.net/ZYS10000/article/details/133692423