HTML5提供了一些非常强大的JavaScript和HTML API,来帮助开发者构建精彩的桌面和移动应用程序。本文将介绍5个新型的API,希望对你的开发工作有所帮助。

1.  全屏API(Fullscreen API)

该API允许开发者以编程方式将Web应用程序全屏运行,使Web应用程序更像本地应用程序。

  1. // 找到适合浏览器的全屏方法
  2. function launchFullScreen(element) {
  3. if(element.requestFullScreen) {
  4. element.requestFullScreen();
  5. } else if(element.mozRequestFullScreen) {
  6. element.mozRequestFullScreen();
  7. } else if(element.webkitRequestFullScreen) {
  8. element.webkitRequestFullScreen();
  9. }
  10. }
  11. // 启动全屏模式
  12. launchFullScreen(document.documentElement); // the whole page
  13. launchFullScreen(document.getElementById("videoElement")); // any individual element

教程 / 演示

2.  页面可见性API(Page Visibility API)

该API可以用来检测页面对于用户的可见性,即返回用户当前浏览的页面或标签的状态变化。

  1. // 设置隐藏属性和可见改变事件的名称,属性需要加浏览器前缀
  2. // since some browsers only offer vendor-prefixed support
  3. var hidden, state, visibilityChange;
  4. if (typeof document.hidden !== "undefined") {
  5. hidden = "hidden";
  6. visibilityChange = "visibilitychange";
  7. state = "visibilityState";
  8. } else if (typeof document.mozHidden !== "undefined") {
  9. hidden = "mozHidden";
  10. visibilityChange = "mozvisibilitychange";
  11. state = "mozVisibilityState";
  12. } else if (typeof document.msHidden !== "undefined") {
  13. hidden = "msHidden";
  14. visibilityChange = "msvisibilitychange";
  15. state = "msVisibilityState";
  16. } else if (typeof document.webkitHidden !== "undefined") {
  17. hidden = "webkitHidden";
  18. visibilityChange = "webkitvisibilitychange";
  19. state = "webkitVisibilityState";
  20. }
  21. // 添加一个标题改变的监听器
  22. document.addEventListener(visibilityChange, function(e) {
  23. // 开始或停止状态处理
  24. }, false);

教程 / 演示

3.  getUserMedia API

该API允许Web应用程序访问摄像头和麦克风,而无需使用插件。

  1. // 设置事件监听器
  2. window.addEventListener("DOMContentLoaded", function() {
  3. // 获取元素
  4. var canvas = document.getElementById("canvas"),
  5. context = canvas.getContext("2d"),
  6. video = document.getElementById("video"),
  7. videoObj = { "video": true },
  8. errBack = function(error) {
  9. console.log("Video capture error: ", error.code);
  10. };
  11. // 设置video监听器
  12. if(navigator.getUserMedia) { // Standard
  13. navigator.getUserMedia(videoObj, function(stream) {
  14. video.src = stream;
  15. video.play();
  16. }, errBack);
  17. } else if(navigator.webkitGetUserMedia) { // WebKit-prefixed
  18. navigator.webkitGetUserMedia(videoObj, function(stream){
  19. video.src = window.webkitURL.createObjectURL(stream);
  20. video.play();
  21. }, errBack);
  22. }
  23. }, false);

教程 / 演示

4.  电池API(Battery API)

这是一个针对移动设备应用程序的API,主要用于检测设备电池信息。

  1. var battery = navigator.battery || navigator.webkitBattery || navigator.mozBattery;
  2. // 电池属性
  3. console.warn("Battery charging: ", battery.charging); // true
  4. console.warn("Battery level: ", battery.level); // 0.58
  5. console.warn("Battery discharging time: ", battery.dischargingTime);
  6. // 添加事件监听器
  7. battery.addEventListener("chargingchange", function(e) {
  8. console.warn("Battery charge change: ", battery.charging);
  9. }, false);

教程

5.  Link Prefetching

预加载网页内容,为浏览者提供一个平滑的浏览体验。

  1. <!-- full page -->
  2. <link rel="prefetch" href="http://davidwalsh.name/css-enhancements-user-experience" />
  3. <!-- just an image -->
  4. <link rel="prefetch" href="http://davidwalsh.name/wp-content/themes/walshbook3/images/sprite.png" />

教程

5 个强大的 HTML5 API的更多相关文章

  1. 你可能不知道的5个功能强大的 HTML5 API

    HTML5 新增了许多重要的特性,像 video.audio 和 canvas 等等,这些特性使得能够很容易的网页中包含多媒体内容,而不需要任何的插件或者 API.而其它的新元素,例如 section ...

  2. 你可能不知道的5 个强大的HTML5 API 函数

    HTML5提供了一些非常强大的JavaScript和HTML API,来帮助开发者构建精彩的桌面和移动应用程序.本文将介绍5个新型的API,希望对你的开发工作有所帮助. 1.  全屏API(Fulls ...

  3. HTML5 API 是什么

    HTML5 API 是什么 一.总结 1.html5有很多好的api可以用:例如绘图的canvas,获取地理位置的,获取手机电池信息的等等,后面用的时候可以百度 2.html5 API是什么:html ...

  4. Ionic – 强大的 HTML5 Mobile App 开发框架

    Ionic 是一个强大的 HTML5 应用程序开发框架,可以帮助您使用 Web 技术,比如 HTML.CSS 和 Javascript 构建接近原生体验的移动应用程序.Ionic 主要关注外观和体验, ...

  5. HTML5 API 之 history

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  6. HTML5 API's (Application Programming Interfaces)

    New HTML5 API's (Application Programming Interfaces) The most interesting new API's are: HTML Geoloc ...

  7. Web开发者的最爱 5个超实用的HTML5 API

    摘要:毫无疑问,HTML5已经成为当今最流行的一门技术,尤其是Web开发者们对HTML5的兴趣是日趋渐浓.HTML5的许多功能也都能在现代浏览器中得以实现.然而,作为开发者,除了关注HTML5的功能和 ...

  8. HTML5+ API 学习

    HTML5+ API 模块整理 API Reference 模块 中文 模块介绍 Accelerometer 加速计 管理设备加速度传感器,用于获取设备加速度信息,包括x(屏幕水平方向).y(垂直屏幕 ...

  9. Java8新特性(二)——强大的Stream API

    一.强大的Stream API 除了Lambda表达式外,Java8另外一项重大更新便是位于java.util.stream.*下的Stream API Stream 是 Java8 中处理集合的关键 ...

随机推荐

  1. 深入理解LinkedBlockingQueue

      说明 通过阅读源码,了解LinkedBlockingQueue的特性.本文基于JDK1.7源码 正文 通过查询API对LinkedBlockingQueue特点进行简单的了解: LinkedBlo ...

  2. 4.java设计模式-原型模式(prototype)

    在<JAVA与模式>一书中开头是这样描述原型(Prototype)模式的: 原型模式属于对象的创建模式.通过给出一个原型对象来指明所有创建的对象的类型,然后用复制这个原型对象的办法创建出更 ...

  3. 用手机管理及维护MySQL,Oracle等数据库

    现在移动办公的情况及需求越来越多,平时MySQL,Oracle,SQLServer等数据库的管理都要通过客户端工具操作,现在有一款基于web网页的软件:TreeSoft数据库管理系统,在服务器布署一套 ...

  4. PoPo数据可视化周刊第4期

    PoPo数据可视化 聚焦于Web数据可视化与可视化交互领域,发现可视化领域有意思的内容.不想错过可视化领域的精彩内容, 就快快关注我们吧 :) 微信号:popodv_com   由于国庆节的原因,累计 ...

  5. UOJ#55. 【WC2014】紫荆花之恋

    传送门 暴力思路就是每次点分治计算答案 点分治之后,条件可以变成 \(dis_i-r_i\le r_j-dis_j\) 每次只要查找 \(r_j-dis_j\) 的排名然后插入 \(dis_j-r_j ...

  6. visual studio 2015通过附加进程调试wcf服务

    网站: 打开wcf服务所在的项目 然后调用iis上部署的HLFC(crm)项目的接口就可以进行调试 注意 WCF服务项目要以管理员身份打开,调用wcf服务的项目要在iis中部署并点击调用后才能在附加到 ...

  7. 谁动了我的Mac ??

    教大家一种方法,看看有没有人在自己对Mac睡眠后对其进行唤醒 一:应用程序里有个控制台,可以将这个打开,输入wake reason 二:在终端输入:syslog |grep -i "Wake ...

  8. notepad 操作总结

    1.竖向选择 先把鼠标光标放在起始位置,然后同时按 Alt+Ctrl 或Alt+shift键,然后移动鼠标选取内容. Word中只能用Alt+Shift .

  9. 类型安全的EventHandlerList

    我们写一个类时,有时候会在同一个类上添加很多事件,事件很多的话,是不容易管理的,.NET提供的EventHandlerList可以辅助多个事件的管理,但不方便的地方是,它不是类型安全的,缺少类型安全, ...

  10. HBuilder:一个不错的web前端IDE(代码编辑器)

    Web前端开发,2000之后基本就是三剑客的天下.到现在DW也是不错的HTMLcoder,如今的前端开发早已是JS的天下.但是DW对于JS方面就弱爆了.DW虽然支持JS语法高亮也支持JQuery Jq ...