通过JS判断网络状态调研及实例demo说明

官方文档

English Document

demo地址

[demo]http://mjs.sinaimg.cn/wap/online/cms/article/cm/network.html)
demo来源于地址http://www.w3cmark.com/2016/442.html

摘要

在设备的使用中,这个Network Information API用于 web 尝试处理网络连接信息。

用例与需求

本文档尝试处理来自于Review of Apps that Use Network Information的需求,如下:

  • 提供获取当前网络连接的类型在系统与网络有交互的时候,这个信息需要在页面加载完毕立刻被提供,或者在尽可能接近加载完毕状态提供
  • 提供一种脚本可以被通知到的方式如果这个连接类型有改变。这样就可以允许开发者动态的改变DOM且或者通知用户他们的网络类型有变化(这种变化会在某种程度上影响这他们)

使用用例(官方文档)

EXAMPLE 1
//得到网络链接类型
var type = navigator.connection.type;

// 在第一次网络跳跃的时候得到下行最大比特率
var max = navigator.connection.downlinkMax;

function changeHandler(e) {
  // 网络链接改变时处理函数
}

// 注册网络链接改变事件
navigator.connection.onchange = changeHandler;

// 另一种注册方式
navigator.connection.addEventListener('change', changeHandler);

连接类型

  • bluetooth
    蓝牙连接
  • cellular
    A cellular connection (e.g., EDGE, HSPA, LTE, etc.).
  • ethernet
    以太网链接
    none
  • No network connection.
    没有网络链接.等同于 navigator.onLine === false
  • mixed
    用户代理用的多个链接类型
  • other
    链接类型未知
  • unknown
    用户代理建立了链接,但是不能够或者不愿意确定潜在的网络连接类型
  • wifi
    wifi连接
  • wimax
    wifimax连接
    以上的链接类型都可以通过ConnectionType枚举

ConnectionType枚举

enum ConnectionType {
    "bluetooth",
    "cellular",
    "ethernet",
    "mixed",
    "none",
    "other",
    "unknown",
    "wifi",
    "wimax"
};

以上为尝试翻译的官方文档前几行

个人测试说明:

由于在业务中最为关心当前网络状态是否为wifi,所以仅判断了当前APP是否支持navigator.connection.type判断其是否可以正则匹配到wifi
测试结果整理表格如下:

机型 系统版本 浏览器 版本 结论
小米5 A7.0 weixin 6.5 type:wifi 支持
小米5 A7.0 weibo 7.5 type:wifi 支持
小米5 A7.0 UC 11.6.2 type:wifi 支持
华为MT7 A5.1.1 UC 11.6.2 type:wifi 支持
华为P9 A6.0 weibo 7.7.0 type:wifi 支持
华为P9 A6.0 UC 11.0.4 type:5(wifi) 支持
华为P9 A6.0 QQ 6.6.8 type:wifi 支持
红米Note A5.0.2 UC 11.6.1 type:wifi 支持
iPhone 10_3_2 weixin 6.5.12 type:未知 NetType wifi 支持
iPhone 10_3_2 QQ 7.1.5 type:未知 NetType wifi 支持
三星Note5 A6.0 原生 5.4 type:wifi 支持
三星Note5 A6.0 weibo 6.12.3 type:wifi 支持
vivo X9 A6.0 weibo 7.7.0 type:wifi 支持
vivo X9 A7.0 weixin 6.5 type:wifi 支持

当前测试初步结论:

  • navigator.connectionAPI不支持:
    iphone(微信、微博、UC、QQ浏览器、百度浏览器)安卓(QQ浏览器)
  • 支持navigator.connection但不能获取到具体网络type:
    安卓(百度浏览器)
  • 支持navigator.connection且可获取到type(大多数):
    安卓(UC、微信、微博)

当前测试特例

支持navigator.connection且可获取到type(大多数)中特例如下:

机型 系统版本 浏览器 版本 结论
红米Note 5.0 weibo 7.7.1 type:unknown 不支持

[type:unknown]属于支持navigator.connection但不能获取到具体网络type
华为p9不返回wifi字样 而是通过数字标识

机型 系统版本 浏览器 版本 结论
华为P9 A6.0 UC 11.0.4 type:5(wifi) 支持
华为P9 A6.0 UC 11.0.4 type:2(4g) 支持

当前测试结论:

由于测试手机有限,并未覆盖到安卓各种版本与机型,若有错误还请提出
暂认为安卓UC、微博支持较好
微信在安卓和ios另有可以获取的方式

微信/QQ获取状态说明

微信和qq我们可以通过另一种方式在安卓、IOS拿到网络状态
微信UA如下:

/*
 * 微信ua  
 */
Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_2 like Mac OS X) AppleWebKit/603.2.4 (KHTML, like Gecko) Mobile/14F89 MicroMessenger/6.5.12 NetType/WIFI Language/zh_CN
/*
 * QQua
 */
Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_2 like Mac OS X) AppleWebKit/603.2.4 (KHTML, like Gecko) Mobile/14F89 QQ/7.1.5.428 V1_IPH_SQ_7.1.5_1_APP_A Pixel/750 Core/UIWebView NetType/WIFI QBWebViewType/1

Mozilla/5.0 (iPhone; CPU iPhone OS 10_3_2 like Mac OS X) AppleWebKit/603.2.4 (KHTML, like Gecko) Mobile/14F89 QQ/7.1.5.428 V1_IPH_SQ_7.1.5_1_APP_A Pixel/750 Core/UIWebView NetType/2G QBWebViewType/1

从UA中看到我们可以通过如下方式进行判断:

if(/NetType/.test(ua)){
    var type = ua.match(/NetType\/(\S*)/);
    network_state = type[1];
}

其它补充

官方文档中给了其它的方法,但是基本都不支持,所以也就没有进行方法的使用和测试,对应的文档也没有翻译但是其中的onchange事件是可以被支持的,通过监控onchange事件监控到网络的改变。
通过枚举navigator.connection属性发现:UC浏览器只支持ontypechange,其它有的使用onchange,有的使用ontypechange,所以使用时需要做兼容处理。

【如有错误还请指正】

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容