前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >判断用户是否断网navigator.onLine

判断用户是否断网navigator.onLine

作者头像
javascript.shop
发布2019-09-04 16:28:55
3.1K0
发布2019-09-04 16:28:55
举报
文章被收录于专栏:杰的记事本杰的记事本

很多时候 web 网页上需要判断或监听浏览器(系统)的网络状态。

Navigator onLine 属性 onLine 属性是一个只读的布尔值,声明了系统是否处于脱机模式,如果系统属于脱机状态,则返回 false,否则返回 true。

注:在 IE 4+ 中,用户可以在浏览器中选择脱机工作,当脱机工作被选后,系统就进入了脱机状态,内容将从缓存进行读取。

语法:navigator.onLine

所有主要浏览器都支持 onLine 属性

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width,initial-scale=1.0"/>
    <title>网络状态</title>
    <style type="text/css">
    </style>
    <!-- JQuery CDN -->
    <script src="https://code.jquery.com/jquery-3.3.1.min.js"
            integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="
            crossorigin="anonymous"></script>
    <script type="text/javascript">
        $(function () {
            $("button").click(function () {
                if (navigator.onLine) {
                    console.log("online");
                    $("div").append("网络正常\t");
                } else {
                    console.log("offline");
                    $("div").append("网络离线\t");
                }
            });
        });
    </script>
</head>
<body>
<button>获取网络状态</button>
<div></div>
</body>
</html>

PC 端亲测结果:

1)当将电脑网络禁用,或者直接拔掉网线,点击按钮时,navigator.onLine 返回 false 2)当浏览器能正常上网,点击按钮时,navigator.onLine 返回 true 3)当手动修改电脑 IP 地址,使 ip 异常浏览器无法上网时,点击按钮,navigator.onLine 返回 taue,

手机端亲测结果:

1)当关闭 WIFI 与 流量时,点击按钮时,navigator.onLine 返回 false

2)当打开 WIFI 或者 流量时,点击按钮,navigator.onLine 返回 true

扩展

[HTML5 API中Network Information API]:(https://github.com/AurelioDeRosa/HTML5-API-demos):

我们可以通过事件的件的监听,去实时获取到网络状态的变化 window.addEventListener(‘offline’, function(e) {alert(‘offline’);}) window.addEventListener(‘online’, function(e) {alert(‘online“’);})

拓展[HTML5 API中Network Information API]:(https://github.com/AurelioDeRosa/HTML5-API-demos):

connection connection也是navigator的一个属性,他包含了一些当前连接的基本信息,其中connection.type值的就是当前的网络类型。其值包含了一下几个:

当网络类型发生变化时,同样的也是可以通过事件监听的方式来实时获取到网络类型。代码实现如下: var connection = navigator.connection || navigator.mozConnection || navigator.webkitConnection; var type = connection.type; function updateConnectionStatus() { alert(“网络由 ” + type + ” 变化为 ” + connection.type); } //监听网络类型发生变化 connection.addEventListener(‘typechange’, updateConnectionStatus);

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年10月15日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 扩展
相关产品与服务
内容分发网络 CDN
内容分发网络(Content Delivery Network,CDN)通过将站点内容发布至遍布全球的海量加速节点,使其用户可就近获取所需内容,避免因网络拥堵、跨运营商、跨地域、跨境等因素带来的网络不稳定、访问延迟高等问题,有效提升下载速度、降低响应时间,提供流畅的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档