文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

javascript中检测网络的方法

2023-06-15 03:48

关注

这篇文章将为大家详细讲解有关javascript中检测网络的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

javascript检测网络的方法:1、通过navigator去检测网络;2、 使用“window.ononline”和“window.onoffline”事件监听浏览器的联网状态;3、通过ajax请求检测网络。

本文操作环境:windows7系统、javascript1.8.5版,DELL G3电脑

JavaScript 判断网络状态

一、一般来说,判断网络状态都是用的 HTML5 提供的 navigator 去检测网络

<script type="text/javascript">// 通过window.navigator.onLine 来检测网络是否可用    alert(window.navigator.onLine); // 返回的是一个bool值(true表示已连接,false表示未连接)</script>

javascript中检测网络的方法

二、想要监听浏览器的联网状态, 使用window.ononline和window.onoffline事件:

<script type="text/javascript">    window.addEventListener("offline",function(){alert("网络连接恢复");})    window.addEventListener("online",function(){alert("网络连接中断");})</script>

或者:

<script type="text/javascript">    window.ononline=function(){alert("网络连接恢复");}    window.onoffline=function(){alert("网络连接中断");}</script>

javascript中检测网络的方法
注意:此方法属于 “侦听器”,在网络连接 / 断开的一瞬间,才会触发。

总结:navigator.onLineonlineoffline事件却不是万能的,在 PC 端时只能判断无线和网线是否连接,而不能判断是否有网络、是否可以上网。

更为安全的做法:

<script type="text/javascript">var el = document.body;  if (el.addEventListener) {     window.addEventListener("online", function () {       alert("网络连接恢复");}, true);     window.addEventListener("offline", function () {       alert("网络连接中断");}, true);  }  else if (el.attachEvent) {     window.attachEvent("ononline", function () {       alert("网络连接恢复");});     window.attachEvent("onoffline", function () {       alert("网络连接中断");});  }  else {     window.ononline = function () {       alert("网络连接恢复");};     window.onoffline = function () {       alert("网络连接中断");};  }  </script>

注意,检测 ononline 事件,要绑定在 window 对象上

attachEvent —— 兼容:IE7、IE8;不兼容 firefox、chrome、IE9、IE10、IE11、safari、opera
addEventListener —— 兼容:firefox、chrome、IE、safari、opera;不兼容 IE7、IE8

推荐学习:《javascript高级教程》

三、可以发起 ajax 请求,根据请求结果判断网络的通断

<script type="text/javascript">$.ajax({  url: 'https://sug.so.360.cn/suggest',  dataType:'jsonp',  success: function(result){    console.log('网络正常')  },   error: function(result){    console.log('网络异常')  }});</script>

当然这种方法也不是很完美,而且不是很实用,无法很好的区分是服务器出现故障还是用户的网络有问题,但是这确实最有效的方式。

关于“javascript中检测网络的方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯