HT ML 5提供了一些非常强大的JavaScript和HTML API,来帮助 开发者 构建精彩的桌面和移动应用程序。本文将介绍5个新型的API,希望对你的开发工作有所帮助。
1.&nbs p; 全屏API(Fullscreen API)
该API允许开发者以 编程方式 将Web应用程序全屏运行,使Web应用程序更像本地应用程序。
复制代码
代码如下:
// 找到适合浏览器的全屏方法
function launchFullScreen(element) {
if(element.requestFullScreen) {
element.requestFullScreen();
} else if(element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if(element. webkit RequestFullScreen) {
element.webk IT RequestFullScreen();
}
}
// 启动全屏模式
launchFullScreen(document.documentElement); // the whole page
launchFullScreen(document.getElementById("videoElement")); // any individual element
2. 页面可见性API(Page Visibility API)
该API可以用来检测页 面对 于用户的可见性,即返回用户当前浏览的页面或标签的状态变化。
复制代码
代码如下:
// 设置隐藏属性和可见 改变 事件的名称,属性需要加浏览器前缀
// since some br owsers only offer vendor- PR efixed support
VAR hidden, stat e, visibilityChange;
if (ty PE of document.hidden ! == "un define d") {
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);
3. getUserMedia API
该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(stre am ) {
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);
4. 电池 API(Battery API)
这是一个针对移动设备应用程序的API,主要用于检测设备 电 池信息。
复制代码
代码如下:
var battery = navigator.battery || navigator.webkitBattery || navigator.mozBattery;
// 电池属性
console.warn("Battery ch arg ing: ", battery.char gin g); // 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);
5. Link Prefetching
预加载 网页内容 ,为 浏览者 提供一个 平滑 的浏览体验。
复制代码
代码如下:
<!-- full page -->
<link rel="prefetch" hr ef="<a href="http://davidwalsh.name/css-enhancements-user-e xp erience">http://davidwalsh.name/css-enhancements-user-experience</a>" />
<!-- just an image -->
以上就是这5个新型的API了,小伙伴们 了解 了吗,有什么疑问请留言,大家一起讨论,共同进步。
总结
以上是 为你收集整理的 5 个强大的HTML5 API 函数推荐 全部内容,希望文章能够帮你解决 5 个强大的HTML5 API 函数推荐 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于5 个强大的HTML5 API 函数推荐的详细内容...