0

0

HTML5:探索网络信息 API

王林

王林

发布时间:2023-08-28 19:09:06

|

926人浏览过

|

来源于php中文网

原创

html5:探索网络信息 api

简介

网页设计领域讨论最多的概念之一是响应式网页设计。关于响应式网页设计的文章已有数千篇,因此我不会在本文中讨论它。然而,响应式网页设计有一个重要的限制,响应式网页设计大部分是基于浏览器视口的大小。

虽然这种方法非常适合提供正确尺寸和分辨率的图像,但它并不适合所有情况,视频内容就是一个例子。在这些情况下,我们真正需要的是有关设备网络连接的更多信息。

假设您正在智能手机或平板电脑上访问 YouTube。您在家并通过 Wi-Fi 连接。在这种情况下,您并不关心正在下载的字节数,您只对高质量视频内容感兴趣。如果您通过慢速移动连接进行连接,则情况并非如此。在这种情况下,您想看视频,质量是次要的。

我应该明确的是,每个希望网站真正优秀的开发者仍然必须优化其所提供的资源,以允许页面尽可能快地加载。不过,在上面的示例中,提供高分辨率视频并不是浪费用户的带宽,而是改善了用户体验。

立即学习前端免费学习笔记(深入)”;

网络信息 API 正是我们需要了解有关设备网络连接的更多信息的地方。

1.它是什么?

网络信息 API 提供对系统用于与网络、蜂窝网络、Wi-Fi、蓝牙等进行通信的连接类型的访问。它还提供了一种在连接类型发生变化时通知脚本的方法。这是为了允许开发人员对 DOM 进行动态更改和/或通知用户网络连接类型已更改。

网络信息 API 规范于 2011 年首次发布,但此后该 API 已发生多次更改。作为证明,当前版本只是编辑草稿,这意味着将来肯定会发生变化。

尽管发生了这些变化,但该 API 的用例非常有趣,确实值得探索。在本文中,我们将讨论该规范的最新版本,但我们还将查看一些已弃用的属性和事件,原因我将在稍后解释。

2.实施

当前版本的网络信息 API 公开了属于 window.navigator 对象的 connection 对象。 connection 对象包含一个属性,type,该属性返回用户代理的连接类型。 type 属性可以具有以下值之一:

  • 蓝牙

  • cellular
  • 以太网
  • none
  • wifi
  • 其他
  • 未知

其中一些值是不言自明的,例如 bluetoothwifi,而其他值则需要更多解释。 cellular 类型是指移动连接,例如 EDGE、3G、4G 等。 other 类型表示当前连接类型不是 unknown,但它也不是任何其他类型。 unknown 类型表示用户代理已建立网络连接,但无法确定连接类型是什么。

除了 type 之外,网络信息 API 还公开 ontypechange 事件。每次网络连接类型发生变化时都会触发它。

开发者可以使用网络信息 API 根据当前的连接类型更改某些功能。例如,如果我们检测到设备正在使用移动连接,我们可以减慢占用大量带宽的进程。 API 还允许我们将特定的类分配给 html 元素,例如 high-bandwidth,与 Modernizr 的方式相同。我们可以利用 CSS 更改元素的一个或多个属性,例如背景图像。

既然我们知道了 Network Information API 的作用以及我们可以从中受益,那么让我们看看哪些浏览器支持该 API。

BJXSHOP网上购物系统 - 书店版
BJXSHOP网上购物系统 - 书店版

BJXSHOP购物管理系统是一个功能完善、展示信息丰富的电子商店销售平台;针对企业与个人的网上销售系统;开放式远程商店管理;完善的订单管理、销售统计、结算系统;强力搜索引擎支持;提供网上多种在线支付方式解决方案;强大的技术应用能力和网络安全系统 BJXSHOP网上购物系统 - 书店版,它具备其他通用购物系统不同的功能,有针对图书销售而进行开发的一个电子商店销售平台,如图书ISBN,图书目录

下载

3.浏览器支持

在撰写本文时,网络信息 API 仅受使用其供应商前缀的 Firefox 和 Chrome Canary 支持。在 Chrome Canary 中,我们必须启用实验性网络平台功能标志才能使用 API。您可以在 Paul Irish 的这篇文章中找到更多信息。

好像对网络信息 API 的支持还不够差,最新版本 30 版的 Firefox 支持旧的 API 规范。因此,如果您现在想使用 Network Information API,请务必查看以前的 API 规范公开的属性和事件。

旧规范公开了两个属性:bandwidthmeteredbandwidth 属性是一个双精度值,表示当前带宽的估计值(以兆字节每秒 (MB/s) 为单位)。 metered 属性是一个布尔值,指定设备的网络连接是否受到任何限制。之前的规范还定义了 onchange 事件,以通知任何侦听器上述属性的更改。

为了让您了解规范的新版本和旧版本,在下一节中我们将构建一个使用这两个版本的演示。

4. 演示

到目前为止,我们已经介绍了 API 公开的属性和事件以及 API 的用例。在本部分中,我们将创建一个简单的网页来查看 API 的运行情况。

该演示由一个 HTML5 页面组成,该页面包含一个包含三个列表项的无序列表。每个项目都包含一个文本片段,用于验证网络信息 API 的旧规范和新规范公开的属性值。列表项默认隐藏,仅在支持相应属性时才显示。

该演示还检测浏览器是否实现旧的 API 规范(针对 Firefox)以及浏览器是否支持网络信息 API。在第一种情况下,您将看到支持旧 API 版本消息,在第二种情况下,将显示不支持 API 消息。

网络信息 API 支持的测试非常简单,如下所示:

// Deal with vendor prefixes
var connection = window.navigator.connection    ||
                 window.navigator.mozConnection ||
                 null;
if (connection === null) {
   // API not supported :(
} else {
   // API supported! Let's start the fun :)
}

要检测实现的版本是否是旧规范,我们可以测试 metered 属性是否存在,如下所示:

if ('metered' in connection) {
   // Old version
} else {
   // New version
}

一旦我们测试了对网络信息 API 的支持,并确定了浏览器支持的规范版本,我们就可以将处理程序附加到正确的事件。在处理程序内,我们更新相应列表项的文本,例如新 API 规范的 type

您可以在下面找到演示的完整代码,如果您愿意,也可以使用它。



   
      
      
      
      Network Information API Demo by Aurelio De Rosa
      
   
   
      

Network Information API

Demo created by Aurelio De Rosa (@AurelioDeRosa).
This demo is part of the HTML5 API demos repository.

结论

在本文中,我向您介绍了网络信息 API。在本文的第一部分中,我们讨论了 API 是什么以及它可以为我们做什么。我们还了解了 Network Information API 公开了哪些属性和事件。正如我在浏览器支持中提到的,该 API 目前支持不佳,部分原因是 API 规范发生了一些变化。

网络信息 API 使用起来非常简单,一旦更多浏览器支持它,就没有理由不利用它提供的信息。您觉得这个 API 怎么样?当更多浏览器支持时您会使用它吗?

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

506

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

427

2024.03.06

html5从入门到精通汇总
html5从入门到精通汇总

想系统掌握HTML5开发?本合集精选全网优质学习资源,涵盖免费教程、实战项目、视频课程与权威电子书,从基础语法到高级特性(Canvas、本地存储、响应式布局等)一应俱全,适合零基础小白到进阶开发者,助你高效入门并精通HTML5前端开发。

21

2025.12.30

html5新老标签汇总
html5新老标签汇总

HTML5在2026年持续优化网页语义化与交互体验,不仅引入了如<header>、<nav>、<article>、<section>、<aside>、<footer>等结构化标签,还新增了<video>、<audio>、<canvas>、<figure>、<time>、<mark>等增强多媒体与

19

2025.12.30

html5空格代码怎么写
html5空格代码怎么写

在HTML5中,空格不能直接通过键盘空格键实现,需使用特定代码。本合集详解常用空格写法:&nbsp;(不间断空格)、&ensp;(半个中文空格)、&emsp;(一个中文空格)及CSS的white-space属性等方法,帮助开发者精准控制页面排版,避免因空格失效导致布局错乱,适用于新手入门与实战参考。

73

2025.12.30

html5怎么做网站教程
html5怎么做网站教程

想从零开始学做网站?这份《HTML5怎么做网站教程》合集专为新手打造!涵盖HTML5基础语法、页面结构搭建、表单与多媒体嵌入、响应式布局及与CSS3/JavaScript协同开发等核心内容。无需编程基础,手把手教你用纯HTML5创建美观、兼容、移动端友好的现代网页。附实战案例+代码模板,快速上手,轻松迈出Web开发第一步!

153

2025.12.31

HTML5建模教程
HTML5建模教程

想快速掌握HTML5模板搭建?本合集汇集实用HTML5建模教程,从零基础入门到实战开发全覆盖!内容涵盖响应式布局、语义化标签、Canvas绘图、表单验证及移动端适配等核心技能,提供可直接复用的模板结构与代码示例。无需复杂配置,助你高效构建现代网页,轻松上手前端开发!

25

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

35

2025.12.31

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号