5 个强大的 HTML5 API
HTML5提供了一些非常强大的JavaScript和HTML API,来帮助开发者构建精彩的桌面和移动应用程序。本文将介绍5个新型的API,希望对你的开发工作有所帮助。
该API允许开发者以编程方式将Web应用程序全屏运行,使Web应用程序更像本地应用程序。
- // 找到适合浏览器的全屏方法
 - function launchFullScreen(element) {
 - if(element.requestFullScreen) {
 - element.requestFullScreen();
 - } else if(element.mozRequestFullScreen) {
 - element.mozRequestFullScreen();
 - } else if(element.webkitRequestFullScreen) {
 - element.webkitRequestFullScreen();
 - }
 - }
 - // 启动全屏模式
 - launchFullScreen(document.documentElement); // the whole page
 - launchFullScreen(document.getElementById("videoElement")); // any individual element
 
2. 页面可见性API(Page Visibility API)
该API可以用来检测页面对于用户的可见性,即返回用户当前浏览的页面或标签的状态变化。
- // 设置隐藏属性和可见改变事件的名称,属性需要加浏览器前缀
 - // since some browsers only offer vendor-prefixed support
 - var hidden, state, visibilityChange;
 - if (typeof document.hidden !== "undefined") {
 - hidden = "hidden";
 - visibilityChange = "visibilitychange";
 - state = "visibilityState";
 - } else if (typeof document.mozHidden !== "undefined") {
 - hidden = "mozHidden";
 - visibilityChange = "mozvisibilitychange";
 - state = "mozVisibilityState";
 - } else if (typeof document.msHidden !== "undefined") {
 - hidden = "msHidden";
 - visibilityChange = "msvisibilitychange";
 - state = "msVisibilityState";
 - } else if (typeof document.webkitHidden !== "undefined") {
 - hidden = "webkitHidden";
 - visibilityChange = "webkitvisibilitychange";
 - state = "webkitVisibilityState";
 - }
 - // 添加一个标题改变的监听器
 - document.addEventListener(visibilityChange, function(e) {
 - // 开始或停止状态处理
 - }, false);
 
该API允许Web应用程序访问摄像头和麦克风,而无需使用插件。
- // 设置事件监听器
 - window.addEventListener("DOMContentLoaded", function() {
 - // 获取元素
 - var canvas = document.getElementById("canvas"),
 - context = canvas.getContext("2d"),
 - video = document.getElementById("video"),
 - videoObj = { "video": true },
 - errBack = function(error) {
 - console.log("Video capture error: ", error.code);
 - };
 - // 设置video监听器
 - if(navigator.getUserMedia) { // Standard
 - navigator.getUserMedia(videoObj, function(stream) {
 - video.src = stream;
 - video.play();
 - }, errBack);
 - } else if(navigator.webkitGetUserMedia) { // WebKit-prefixed
 - navigator.webkitGetUserMedia(videoObj, function(stream){
 - video.src = window.webkitURL.createObjectURL(stream);
 - video.play();
 - }, errBack);
 - }
 - }, false);
 
这是一个针对移动设备应用程序的API,主要用于检测设备电池信息。
- var battery = navigator.battery || navigator.webkitBattery || navigator.mozBattery;
 - // 电池属性
 - console.warn("Battery charging: ", battery.charging); // true
 - console.warn("Battery level: ", battery.level); // 0.58
 - console.warn("Battery discharging time: ", battery.dischargingTime);
 - // 添加事件监听器
 - battery.addEventListener("chargingchange", function(e) {
 - console.warn("Battery charge change: ", battery.charging);
 - }, false);
 
预加载网页内容,为浏览者提供一个平滑的浏览体验。
- <!-- full page -->
 - <link rel="prefetch" href="http://davidwalsh.name/css-enhancements-user-experience" />
 - <!-- just an image -->
 - <link rel="prefetch" href="http://davidwalsh.name/wp-content/themes/walshbook3/images/sprite.png" />
 
5 个强大的 HTML5 API的更多相关文章
- 你可能不知道的5个功能强大的 HTML5 API
		
HTML5 新增了许多重要的特性,像 video.audio 和 canvas 等等,这些特性使得能够很容易的网页中包含多媒体内容,而不需要任何的插件或者 API.而其它的新元素,例如 section ...
 - 你可能不知道的5 个强大的HTML5 API 函数
		
HTML5提供了一些非常强大的JavaScript和HTML API,来帮助开发者构建精彩的桌面和移动应用程序.本文将介绍5个新型的API,希望对你的开发工作有所帮助. 1. 全屏API(Fulls ...
 - HTML5 API 是什么
		
HTML5 API 是什么 一.总结 1.html5有很多好的api可以用:例如绘图的canvas,获取地理位置的,获取手机电池信息的等等,后面用的时候可以百度 2.html5 API是什么:html ...
 - Ionic – 强大的 HTML5 Mobile App 开发框架
		
Ionic 是一个强大的 HTML5 应用程序开发框架,可以帮助您使用 Web 技术,比如 HTML.CSS 和 Javascript 构建接近原生体验的移动应用程序.Ionic 主要关注外观和体验, ...
 - HTML5 API 之 history
		
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
 - HTML5 API's (Application Programming Interfaces)
		
New HTML5 API's (Application Programming Interfaces) The most interesting new API's are: HTML Geoloc ...
 - Web开发者的最爱 5个超实用的HTML5 API
		
摘要:毫无疑问,HTML5已经成为当今最流行的一门技术,尤其是Web开发者们对HTML5的兴趣是日趋渐浓.HTML5的许多功能也都能在现代浏览器中得以实现.然而,作为开发者,除了关注HTML5的功能和 ...
 - HTML5+ API 学习
		
HTML5+ API 模块整理 API Reference 模块 中文 模块介绍 Accelerometer 加速计 管理设备加速度传感器,用于获取设备加速度信息,包括x(屏幕水平方向).y(垂直屏幕 ...
 - Java8新特性(二)——强大的Stream API
		
一.强大的Stream API 除了Lambda表达式外,Java8另外一项重大更新便是位于java.util.stream.*下的Stream API Stream 是 Java8 中处理集合的关键 ...
 
随机推荐
- Echarts 使用asp.net +ashx+ajax 实现  饼图、柱形图后台交互
			
向上效果图 前端code /* * ------------------------------------------------------------------ * module-inform ...
 - 分布式微服务技术之 Spring Cloud Netflix
			
1 背景 Netflix 是全球十大视频网站中唯一收费站点,是美国互联网流媒体播放商,由于访问量巨大,转型为云计算公司. 由Netflix公司主持开发了一套代码框架和库Netflix OSS即open ...
 - 【我整理的java开源项目】
			
摘要: 1. 整理出一些使用比较广或者个人觉得比较好的java开源项目和资料供参考. 2. 如果你觉得好但是我没有列出的开源项目请告诉我,方便我添加到列表里. 3. 如果你发现信息描述有误请联系我,我 ...
 - Linux 安装命令
 - SQL-字符串运算符和函数
			
COALESCE(columnname,string) 函数 将 NULL 值作为字符串(用空字符串或其他字符串替换 NULL)- 接受一列输入值(字段)如果该字段为 NULL,则返回后面替换的字符串 ...
 - sql-pivot
			
PIVOT PIVOT运算符用于在列和行之间进行数据旋转或透视转换,同时执行聚合运算 ,,) Order By empid asc Select * From ( Select empid,YEAR( ...
 - C++学习笔记(3)----类模板的static成员
			
与任何其他类相同,类模板可以声明 static 成员: template <typename T> class Foo { public: static std::size_t count ...
 - volley4--RequestQueue
			
源码: /* * Copyright (C) 2011 The Android Open Source Project * * Licensed under the Apache License, V ...
 - 应用程序 调用 webservice
			
首先用VS创建一个WebService服务工程,并且完成基本功能,本人完成的是html转pdf功能. 然后,新建一个Windows应用程序. 添加WebService到Windows项目中,如图 然后 ...
 - Non-resolvable parent POM for com.*******
			
场景: 同事新打了一个jar包到私服里面,自己删除了本地对应的中央仓库的依赖包,再次重新下载. 于是我又打开了一个idea的窗口重新引入这个项目,然后重新下载依赖的服务. 结果就一直报这个问题... ...