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. Java学习--jsp内置对象

    九个内置对象,其中Out,request,response,session,application常用 get与post区别: request对象: response对象: 请求转发与请求重定向的区别 ...

  2. python学习之老男孩python全栈第九期_day019作业

    # 计算时间差 import time start_time = time.mktime(time.strptime('2017-09-11 08:30:00','%Y-%m-%d %H:%M:%S' ...

  3. Struts2-------领域对象

    领域对象 这个词汇是我在刚开始学习Struts2的时候接触到的,然后再网上查找了一些相关文档,说的最多的就是领域模型.说的挺文字的,自己还是不明白.Model也可说是“领域对象”,包含属性和行为. 好 ...

  4. ActiveMQ的用途

    ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线. ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现. 消息队列的主要作用是为了 ...

  5. 须知的css——margin不重叠的情形

    margin重叠 摘自css2.1规范中文版 CSS中,两个或者多个盒(可能但不一定是兄弟)的相邻的margin会被结合成一个margin.Margin按这种方式结合叫重叠(collapse),产生的 ...

  6. MySQL5.5登陆

    通过cmd登陆 mysql -h localhost -P 3306 -u root -p123456 h后面跟的是域名或IP地址:大写的P后面跟的是端口号:u后面跟的是用户名:小写的p后面跟的是密码 ...

  7. Angular进阶教程一

    6 AngularJS进阶 6.1数据绑定原理研究 Angular用户都想知道数据绑定是怎么实现的.你可能会看到各种各样的词汇:$watch.$apply.$digest.dirty-checking ...

  8. MySQL事务管理

    事务就是一组原子性的SQL查询,或者说一个独立的工作单元.如果数据库引擎能够成功地对数据库应用该组查询的全部语句,那么就执行该组的全部语句,如果其中有任何一条语句因为崩溃或者其他原因无法执行,那么所有 ...

  9. windows&cmd常用命令&快捷键

    1: cls即CLear Screen 功能:清除屏幕上的所有显示 2:Win+Tab快捷键进行3D窗口切换还有比较快速切换窗口的新方法. 3:利用Alt+Tab快捷键进行切换窗口时,在桌面中间会显示 ...

  10. Spring Cloud中,Eureka常见问题总结

    Spring Cloud中,Eureka常见问题总结. 1 eureka.environment: 指定环境 参考文档: 1 eureka.datacenter: 指定数据中心 参考文档: 使用配置项 ...