JavaScript中 判断网络状态的几种方法
为了判断是否离线,在页面加载后,可先通过 navigator.onLine 取得初始的状态,然后通过ononline、onoffline 事件来确定网络连接状态是否变化。一个缺点:navigator.onLine 和 online、offline事件却不是万能的,只能判断无线和网线是否连接,而不能进一步判断该网络是否能够上网。
·
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事件却不是万能的,只能判断无线和网线是否连接,而不能进一步判断该网络是否能够上网。
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)