HTML5:探索网络信息 API

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。

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

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

<!DOCTYPE html>
<html>
   <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
      <meta name="author" content="Aurelio De Rosa">
      <title>Network Information API Demo by Aurelio De Rosa</title>
      <style>
         *
         {
            -webkit-box-sizing: border-box;
            -moz-box-sizing: border-box;
            box-sizing: border-box;
         }

         body
         {
            max-width: 500px;
            margin: 2em auto;
            padding: 0 0.5em;
            font-size: 20px;
         }

         h1
         {
            text-align: center;
         }

         .api-support
         {
            display: block;
         }

         .hidden
         {
            display: none;
         }

         .value
         {
            font-weight: bold;
         }

         .author
         {
            display: block;
            margin-top: 1em;
         }
      </style>
   </head>
   <body>
      <h1>Network Information API</h1>

      <span id="ni-unsupported" class="api-support hidden">API not supported</span>
      <span id="nio-supported" class="api-support hidden">Old API version supported</span>

      <ul>
         <li class="new-api hidden">
            The connection type is <span id="t-value" class="value">undefined</span>.
         </li>
         <li class="old-api hidden">
            The connection bandwidth is <span id="b-value" class="value">undefined</span>.
         </li>
         <li class="old-api hidden">
            The connection is <span id="m-value" class="value">undefined</span>.
         </li>
      </ul>

      <small class="author">
         Demo created by <a href="http://www.audero.it">Aurelio De Rosa</a>
         (<a href="https://twitter.com/AurelioDeRosa">@AurelioDeRosa</a>).<br />
         This demo is part of the <a href="https://github.com/AurelioDeRosa/HTML5-API-demos">HTML5 API demos repository</a>.
      </small>

      <script>
         var connection = window.navigator.connection    ||
                          window.navigator.mozConnection ||
                          null;
         if (connection === null) {
            document.getElementById('ni-unsupported').classList.remove('hidden');
         } else if ('metered' in connection) {
            document.getElementById('nio-supported').classList.remove('hidden');
            [].slice.call(document.getElementsByClassName('old-api')).forEach(function(element) {
               element.classList.remove('hidden');
            });

            var bandwidthValue = document.getElementById('b-value');
            var meteredValue = document.getElementById('m-value');

            connection.addEventListener('change', function (event) {
               bandwidthValue.innerHTML = connection.bandwidth;
               meteredValue.innerHTML = (connection.metered ? '' : 'not ') + 'metered';
            });
            connection.dispatchEvent(new Event('change'));
         } else {
            var typeValue = document.getElementById('t-value');
            [].slice.call(document.getElementsByClassName('new-api')).forEach(function(element) {
               element.classList.remove('hidden');
            });

            connection.addEventListener('typechange', function (event) {
               typeValue.innerHTML = connection.type;
            });
            connection.dispatchEvent(new Event('typechange'));
         }
      </script>
   </body>
</html>

结论

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

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

以上就是HTML5:探索网络信息 API的详细内容,更多请关注编程之家其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


阅读本文之前,分享大家一张图片,看图会发现JavaScript开发需求最高,占比达到42.84%,因此掌握JavaScript语言好工作就不愁啦,工欲善其事必先利其器,那么选择IDE来开发是至关重要的,本文指出常用的几款JavaScript IDE,分析其优缺点,如有不完善的请大家补充
Promises是一种关于异步编程的规范,目的是将异步处理对象和处理规则进行规范化,为异步编程提供统一接口。本文简要的介绍了Promises的基础知识,希望我们我们能够更好的使用Promises,更轻松的编写代码。
引子 Patrick Catanzariti 是一名Web开发工程师,最近他在 sitepoint 发表了《JavaScript Beyond the Web in 2014》,介绍了JavaScript在物联网中的应用,非常有意思。做为JavaScript的爱好者和从业者,我在这里把它翻译了,以飨
小编吐血整理加上翻译,太辛苦了~求赞! 本文主要总结了JavaScript 常用功能总结,如一些常用的JS 对象,基本数据结构,功能函数等,还有一些常用的设计模式。 目录: 众所周知,JavaScript是动态的面向对象的编程语言,能够实现以下效果: 1. 丰富Web 网页功能 2. 丰富Web界面
微软于今日(2015年12月10日)宣布即将开源Chakra核心控件,并改名为“ChakraCore”,该控件包含所有Edge JavaScript 引擎的所有核心功能。ChakraCore 将于下月发布在GitHub中。 Chakra提供了顶级的JavaScript处理功能,并具有非常强大的性能优
通过统计数据库中的1000多个项目,我们发现在 JavaScript 中最常出现的错误有10个。本文会向大家介绍这些错误发生的原因以及如何防止。
TypeScript 和 JavaScript 是目前项目开发中较为流行的两种脚本语言,我们已经熟知 TypeScript 是 JavaScript 的一个超集,但是 TypeScript 与 JavaScript 之间又有什么样的区别呢?在选择开发语言时,又该如何抉择呢?
本文是2017年 JavaScript 框架回顾系列的最后的一篇文章,主要介绍 JavaScript 的后端框架情况。
本文来源于多年的 JavaScript 编码技术经验,适合所有正在使用 JavaScript 编程的开发人员阅读。本文的目的在于帮助大家更加熟练的运用 JavaScript 语言来进行开发工作。
对于前端开发人员来说,如果能够掌握交互式网页中的数据可视化技术,则是一项很棒的技能。当然,通过一些 JavaScript 的图表库也会使前端的数据可视化变得更加容易。
几乎每隔一个星期,就有一个新的 JavaScript 库席卷网络社区!Web 社区日益活跃、多样,并在多个领域快速成长。想要研究每一个重要的 JavaScript 框架和库,是个不可能完成的任务。接下来,我会分享一些前端开发的最著名和最有影响力的框架和库。下面,就让我们一起来看看,顶级的 JavaS
AngularJ.js 由google开发,2009年首次发布 很流行的前端框架 使用Angular.js创建第一个UI,成本很低 对于团队来说,AngularJ.js有许多很棒的工具可用 很适合创建一个快速、混合型复杂的解决方案 比起React,更合适于创建小型企业级应用 由Google负责维护基
Javascript框架(以下简称框架)也被称为Javascript库,是一组包含丰富功能和函数的JavaScript代码集,能够帮助开发者快速完成Web设计和开发工作。随着Web社区的越发活跃,新的框架也层出不穷,目前流行的有:Angular、React、Vue.js和Knockout等。 面对如
对于 JavaScript 社区来说,npm 的主要功能之一就是帮助开发者发掘所需的 npm Registry 中的库和框架。npm 强大的搜索功能能够帮助找到一组相关的软件包,同时其内置的的文档和使用统计信息,可以帮助开发者决定使用哪一种软件包。
前言 SpreadJS作为一款性能出众的纯前端电子表格控件,自2015年发布以来,已经被广泛应用于各领域“在线Excel”数据管理项目中。NPM,作为管理Node.js库最有力的手段,解决了很多NodeJS代码部署的问题。 如今,为让您更方便的使用产品和更好地管理项目中的SpreadJS代码,我们已
前一篇文章中,我们介绍了2017年 JavaScript 框架的整体情况。我们也了解到在众多的前端框架中,目前最为庞大又在快速增长的当属React了,本文就来重点介绍React的生态系统。
ES2017标准已经于2017年6月份正式定稿了,并广泛支持最新的特性:异步函数。如果你曾经被异步JavaScript的逻辑困扰,这么新函数正是为你设计的。
本文将会讨论10个优秀的支持JavaScript,HTML5和CSS开发,并且可以使用Markdown进行文档编写的文本编辑器。
随着现在的编程语言功能越来越成熟、复杂,内存管理也容易被大家忽略。本文将会讨论JavaScript中的内存泄漏以及如何处理,方便大家在使用JavaScript编码时,更好的应对内存泄漏带来的问题。
JavaScript 作为当前最为常见的直译式脚本语言,已经广泛应用于 Web 应用开发中。为了提高Web应用的性能,从 JavaScript 的性能优化方向入手,会是一个很好的选择。本文从加载、上下文、解析、编译、执行和捆绑等多个方面来讲解 JavaScript 的性能优化技巧,以便让更多的前端开