HTML5提供了有些那多少个有力的JavaScript和HTML,API详细介绍

HTML5中与页面显示相关的API

2015/05/15 · HTML5 ·
HTML5

原稿出处:
涂根华的博客   

在HTML5中,扩张了2个与页面显示相关的API,分别是Page Visibility
API与Fullscreen API; 效用分别如下:

Page Visibility API 
是指当页面变为最小化状态或者用户将浏览器标签切换来任何标签时会触发。

Fullscreen API 是将页面全部或页面中某个局部区域设为全屏。

Page Visibility API的使用场地如下:

  1. 一个应用程序中有着多幅图片的幻灯片式的连天播发效果,当页面变为不可见状态(最小化状态或者将用户浏览器标签切换来其它标签时),图片截至播放,当页面变为可见状态时,图片继续播放。
  2. 在一个实时呈现服务器端音信的应用程序中,当页面处于不可见状态(最小化状态或者将用户浏览器标签切换来此外标签时),结束定期向服务器端请求数据的拍卖,当页面变为可见状态,继续执行定期向服务器端请求数据的处理。
  3. 在一个颇具播放录像效果的应用程序中,当页面处于不可见状态(最小化状态或者将用户浏览器标签切换来任何标签时),暂停播放视频,当页面变为可见状态时,继续播放视频。

浏览器匡助程度:Firefox10+,chrome14+,IE10+;

实现Page Visibility API

在动用Page Visibility
API时,大家第一需要看清当前用户所利用的浏览器以及该浏览器是否扶助。代码如下判断:

JavaScript

if(typeof document.hidden !== ‘undefined’) { hidden = ‘hidden’;
visibilityChange = ‘visibilitychange’; }else if(typeof
document.mozHidden !== ‘undefined’) { hidden = ‘mozHidden’;
visibilityChange = ‘mozvisibilitychange’; }else if(typeof
document.msHidden !== ‘undefined’) { hidden = ‘msHidden’;
visibilityChange = ‘msvisibilitychange’; }else if(typeof
document.webkitHidden !== ‘undefined’) { hidden = ‘webkitHidden’;
visibilityChange = ‘webkitvisibilitychange’; }

1
2
3
4
5
6
7
8
9
10
11
12
13
if(typeof document.hidden !== ‘undefined’) {
    hidden = ‘hidden’;
    visibilityChange = ‘visibilitychange’;
}else if(typeof document.mozHidden !== ‘undefined’) {
    hidden = ‘mozHidden’;
    visibilityChange = ‘mozvisibilitychange’;
}else if(typeof document.msHidden !== ‘undefined’) {
    hidden = ‘msHidden’;
    visibilityChange = ‘msvisibilitychange’;
}else if(typeof document.webkitHidden !== ‘undefined’) {        
    hidden = ‘webkitHidden’;
    visibilityChange = ‘webkitvisibilitychange’;
}

如上,在Page Visibility
 API中,可以通过document对象的hidden属性值来判定页面是否处于可见状态,当页面处于可见状态时属性值为false,当页面处于不可见状态时属性值为true。

在Page
Visibility中,可以因而document对象的visibilityState属性值来判定页面的可见状态。该属性值为一个字符串,其意义如下所示:

   
visible:
 页面内容部分可见,当前页面位于用户正在查阅的浏览器标签窗口中,且浏览器窗口未被最小化。

   
hidden:
 页面内容对用户不可见。当前页面不在用户正在查看的浏览器标签窗口中,或浏览器窗口已被最小化。

    prerender: 页面内容已被预渲染,不过对用户不可见。

目前大家来看一个demo,页面中有一个video元素与一个”播放”按钮,用户单击”播放”按钮时
按钮文字变为
’暂停”,同时开班播报video元素的视频,当页面变为最小化状态或用户浏览器标签切换来任何标签时候,视频被暂停播放,当页面复苏正常状态或用户将浏览器标签切回页面所在标签时,视频持续播放。

HTML代码如下:

JavaScript

<video id=”videoElement” controls width=640 height=360 autoplay>
<source src=”Wildlife/Wildlife.ogv” type=’video/ogg; codecs=”theora,
vorbis”‘/> <source src=”Wildlife/Wildlife.webm” type=’video/webm’
> <source src=”Wildlife/Wildlife.mp4″ type=’video/mp4′>
</video> <button id=”btnPlay”
onclick=”PlayOrPause()”>播放</button> <div
style=”height:1500px;”></div>

1
2
3
4
5
6
7
<video id="videoElement" controls width=640 height=360 autoplay>
    <source src="Wildlife/Wildlife.ogv" type=’video/ogg; codecs="theora, vorbis"’/>
    <source src="Wildlife/Wildlife.webm" type=’video/webm’ >
    <source src="Wildlife/Wildlife.mp4" type=’video/mp4′>
</video>
<button id="btnPlay" onclick="PlayOrPause()">播放</button>
<div style="height:1500px;"></div>

JS代码如下:

JavaScript

var hidden, visibilityChange, videoElement; if(typeof document.hidden
!== ‘undefined’) { hidden = ‘hidden’; visibilityChange =
‘visibilitychange’; }else if(typeof document.mozHidden !== ‘undefined’)
{ hidden = ‘mozHidden’; visibilityChange = ‘mozvisibilitychange’; }else
if(typeof document.msHidden !== ‘undefined’) { hidden = ‘msHidden’;
visibilityChange = ‘msvisibilitychange’; }else if(typeof
document.webkitHidden !== ‘undefined’) { hidden = ‘webkitHidden’;
visibilityChange = ‘webkitvisibilitychange’; }
document.add伊夫ntListener(visibilityChange,handle,false); videoElement =
document.getElementById(“videoElement”);
videoElement.add伊芙(Eve)ntListener(‘ended’,videoEnded,false);
videoElement.add伊芙(Eve)ntListener(‘play’,videoPlay,false);
videoElement.add伊夫ntListener(‘pause’,videoPause,false); //
借使页面变为不可见状态 则暂停视频播放 //
假设页面变为可见状态,则持续录像播放 function handle() { //
通过visibilityState属性值判断页面的可见状态
console.log(document.visibilityState); if(document[hidden]) {
videoElement.pause(); }else { videoElement.play(); } } // 播放视频function play() { videoElement.play(); } // 暂停播放 function pause() {
videoElement.pause(); } function PlayOrPause() { if(videoElement.paused)
{ videoElement.play(); }else { videoElement.pause(); } } function
videoEnded(e) { videoElement.current提姆e = 0; this.pause(); } function
videoPlay(e) { var btnPlay = document.getElementById(“btnPlay”);
btnPlay.innerHTML = “暂停”; } function videoPause(e) { var btnPlay =
document.getElementById(“btnPlay”); btnPlay.innerHTML = “播放”; }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
var hidden,
visibilityChange,
videoElement;
if(typeof document.hidden !== ‘undefined’) {
    hidden = ‘hidden’;
    visibilityChange = ‘visibilitychange’;
}else if(typeof document.mozHidden !== ‘undefined’) {
    hidden = ‘mozHidden’;
    visibilityChange = ‘mozvisibilitychange’;
}else if(typeof document.msHidden !== ‘undefined’) {
    hidden = ‘msHidden’;
    visibilityChange = ‘msvisibilitychange’;
}else if(typeof document.webkitHidden !== ‘undefined’) {
    hidden = ‘webkitHidden’;
    visibilityChange = ‘webkitvisibilitychange’;
}
document.addEventListener(visibilityChange,handle,false);
videoElement = document.getElementById("videoElement");
videoElement.addEventListener(‘ended’,videoEnded,false);
videoElement.addEventListener(‘play’,videoPlay,false);
videoElement.addEventListener(‘pause’,videoPause,false);
// 如果页面变为不可见状态 则暂停视频播放
// 如果页面变为可见状态,则继续视频播放
function handle() {
    // 通过visibilityState属性值判断页面的可见状态
    console.log(document.visibilityState);
    if(document[hidden]) {
        videoElement.pause();    
    }else {
        videoElement.play();
    }
}
// 播放视频
function play() {
    videoElement.play();
}
// 暂停播放
function pause() {
    videoElement.pause();
}
function PlayOrPause() {
    if(videoElement.paused) {
        videoElement.play();
    }else {
        videoElement.pause();
    }
}
function videoEnded(e) {
    videoElement.currentTime = 0;
    this.pause();
}
function videoPlay(e) {
    var btnPlay = document.getElementById("btnPlay");
    btnPlay.innerHTML = "暂停";
}
function videoPause(e) {
    var btnPlay = document.getElementById("btnPlay");
    btnPlay.innerHTML = "播放";
}

实现Fullscreen API

在HTML5中,新增了一个Fullscreen
API,其效劳是将页面全体或页面中某个局部区域设为全屏展现状态。

浏览器帮忙程度:Firefox10+,chrome16+,Safari5.1+

在Fullscreen
API中,可以通过DOM对象的根节点目标或某个元素的requestFullscreen属性值和实施相呼应的点子来判定浏览器是否辅助Fullscreen
API。代码如下:

JavaScript

var docElm = document.documentElement; if(docElm.requestFullscreen) {
docElm.requestFullscreen(); }else if(docElm.mozRequestFullScreen) {
docElm.mozRequestFullScreen(); }else if(docElm.webkitRequestFullScreen)
{ docElm.webkitRequestFullScreen(); }

1
2
3
4
5
6
7
8
var docElm = document.documentElement;
if(docElm.requestFullscreen) {
        docElm.requestFullscreen();
}else if(docElm.mozRequestFullScreen) {
        docElm.mozRequestFullScreen();
}else if(docElm.webkitRequestFullScreen) {
        docElm.webkitRequestFullScreen();
}

在Fullscreen
API中,也可以因而DOM对象或某个元素的exitFullscreen与CanvelFullScreen属性和艺术将目前页面或某个元素设定为非全屏显示状态。

一般来说代码:

JavaScript

if(document.exitFullscreen) { document.exitFullscreen(); }else
if(document.mozCancelFullScreen) { document.mozCancelFullScreen(); }else
if(document.webkitCancelFullScreen) { document.webkitCancelFullScreen();
}

1
2
3
4
5
6
7
if(document.exitFullscreen) {
    document.exitFullscreen();
}else if(document.mozCancelFullScreen) {
    document.mozCancelFullScreen();
}else if(document.webkitCancelFullScreen) {
    document.webkitCancelFullScreen();
}

在Fullscreen
API中,能够透过监听DOM对象或某个元素的fullscreenchange事件(当页面或因素从非全屏显示状态成为全屏显示状态,或从全屏呈现状态变成非全屏呈现状态时触发)。代码如下:

JavaScript

document.addEventListener(‘fullscreenchange’,function(){},false);
document.addEventListener(‘mozfullscreenchange’,function(){},false);
document.addEventListener(‘webkitfullscreenchange’,function(){},false);

1
2
3
document.addEventListener(‘fullscreenchange’,function(){},false);
document.addEventListener(‘mozfullscreenchange’,function(){},false);
document.addEventListener(‘webkitfullscreenchange’,function(){},false);

在css样式代码中,我们可以应用伪类采用器来单独指定处于全屏呈现状态的页面或因素样式:

JavaScript

html:-moz-full-screen { background:red; } html:-webkit-full-screen {
background:red; } html:fullscreen { background:red; }

1
2
3
4
5
6
7
8
9
html:-moz-full-screen {
    background:red;
}
html:-webkit-full-screen {
    background:red;
}
html:fullscreen {
    background:red;
}

末段我们来看一个demo,在页面中有一个按钮,点击后,页面会变成全屏状态,再点击后,页面会退出全屏;

HTML代码如下:

JavaScript

<input type=”button” id=”btnFullScreen” value=”页面全屏呈现”
onclick=”toggleFullScreen();”/> <div style=”width:100%;”
id=”fullscreentState”>非全屏彰显</div>

1
2
<input type="button" id="btnFullScreen" value="页面全屏显示" onclick="toggleFullScreen();"/>
<div style="width:100%;" id="fullscreentState">非全屏显示</div>

Javascript如下:

JavaScript

var docElm = document.documentElement; var fullscreentState =
document.getElementById(“fullscreentState”); var btnFullScreen =
document.getElementById(“btnFullScreen”); fullscreentState.style.height
= docElm.clientHeight + ‘px’;
document.add伊芙ntListener(‘fullscreenchange’,function(){
fullscreentState.innerHTML = (document.fullscreen) ? “全屏彰显” :
“非全屏展现”; },false);
document.add伊夫(Eve)ntListener(‘mozfullscreenchange’,function(){
fullscreentState.innerHTML = (document.mozFullscreen) ? “全屏展现” :
“非全屏呈现”; },false);
document.add伊芙ntListener(‘webkitfullscreenchange’,function(){
fullscreentState.innerHTML = (document.webkitFullscreen) ? “全屏展现” :
“非全屏展现”; },false); function toggleFullScreen() {
if(btnFullScreen.value == ‘页面全屏呈现’) { btnFullScreen.value =
‘页面非全屏显示’; if(docElm.requestFullscreen) {
docElm.requestFullscreen(); }else if(docElm.mozRequestFullScreen) {
docElm.mozRequestFullScreen(); }else if(docElm.webkitRequestFullScreen)
{ docElm.webkitRequestFullScreen(); } }else {
if(document.exitFullscreen) { document.exitFullscreen(); }else
if(document.mozCancelFullScreen) { document.mozCancelFullScreen(); }else
if(document.webkitCancelFullScreen) { document.webkitCancelFullScreen();
} btnFullScreen.value = “页面全屏展现”; } }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
var docElm = document.documentElement;
var fullscreentState = document.getElementById("fullscreentState");
var btnFullScreen = document.getElementById("btnFullScreen");
fullscreentState.style.height = docElm.clientHeight + ‘px’;
document.addEventListener(‘fullscreenchange’,function(){
    fullscreentState.innerHTML = (document.fullscreen) ? "全屏显示" : "非全屏显示";
},false);
document.addEventListener(‘mozfullscreenchange’,function(){
    fullscreentState.innerHTML = (document.mozFullscreen) ? "全屏显示" : "非全屏显示";
},false);
document.addEventListener(‘webkitfullscreenchange’,function(){
    fullscreentState.innerHTML = (document.webkitFullscreen) ? "全屏显示" : "非全屏显示";
},false);
function toggleFullScreen() {
    if(btnFullScreen.value == ‘页面全屏显示’) {
        btnFullScreen.value = ‘页面非全屏显示’;
        if(docElm.requestFullscreen) {
            docElm.requestFullscreen();
        }else if(docElm.mozRequestFullScreen) {
            docElm.mozRequestFullScreen();
        }else if(docElm.webkitRequestFullScreen) {
            docElm.webkitRequestFullScreen();
        }
    }else {
        if(document.exitFullscreen) {
            document.exitFullscreen();
        }else if(document.mozCancelFullScreen) {
            document.mozCancelFullScreen();
        }else if(document.webkitCancelFullScreen) {
            document.webkitCancelFullScreen();
        }
        btnFullScreen.value = "页面全屏显示";
    }
}

赞 收藏
评论

澳门葡京 1

HTML5全屏(Fullscreen)API详细介绍,html5fullscreen

这篇随笔紧要介绍了HTML5全屏(Fullscreen)API详细介绍,本文给出了开行全屏模式和剥离全屏格局代码示例,同时讲解了Fullscreen
属性与事件,需要的情人可以参考下

在进一步真实的web应用程序中,JavaScript也变得尤其给力.

FullScreen API 是一个新的JavaScript API,简单而又强大. FullScreen
让我们得以经过编程的法门来向用户请求全屏突显,如若交互完成,随时可以退出全屏状态.

在线演示Demo:  Fullscreen API Example

(在此Demo中,可以Launch ,Hide
,以及Dump显示相关属性,可以通过chrome的控制台查看日志新闻.)

起步全屏形式

全屏API
requestFullscreen方法在一部分老的浏览器里面依旧采用带前缀模式的措施名,因而可能需要开展检测判断:
(带前缀,意思就是各样浏览器内核不通用.)

代码如下:
// 找到扶助的办法, 使用需要全屏的 element 调用
function launchFullScreen(element) {
if(element.requestFullscreen) {
element.requestFullscreen();
} else if(element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if(element.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
} else if(element.msRequestFullscreen) {
element.msRequestFullscreen();
}
}

// 在协助全屏的浏览器中启动全屏
// 整个页面
launchFullScreen(document.documentElement);
// 某个元素
launchFullScreen(document.getElementById(“videoElement”));

将急需全屏彰显的DOM元素作为参数,调用此办法即可让window进入全屏状态,有时候可能需要用户同意(浏览器自己和用户交互),要是用户拒绝,则可能出现各样不完全的全屏.

尽管用户同意进入全屏,那么工具栏以及其余浏览器组件会隐藏起来,使document框架的大幅度和可观横跨所有屏幕.

剥离全屏形式

动用 exitFullscreen 方法可以使浏览器退出全屏,再次回到原先的布局.
该情势在一些老的浏览器上也是帮助前缀方法.

代码如下:
// 退出 fullscreen
function exitFullscreen() {
if(document.exitFullscreen) {
document.exitFullscreen();
} else if(document.mozExitFullScreen) {
document.mozExitFullScreen();
} else if(document.webkitExitFullscreen) {
document.webkitExitFullscreen();
}
}

// 调用退出全屏方法!
exitFullscreen();

请留心: exitFullscreen 只可以通过 document 对象调用 —— 而不是使用普通的
DOM element.

Fullscreen 属性与事件

一个坏音信,到最近截止,全屏事件和方法依然是带前缀的,好信息就是迅速主流浏览器就会都帮助。

1.document.fullscreenElement:  当前居于全屏状态的要素 element.
2.document.fullscreenEnabled:  标记 fullscreen 当前是不是可用.

当进入/退出 全屏情势时,会触发 fullscreenchange 事件:

HTML5提供了有些那多少个有力的JavaScript和HTML,API详细介绍。代码如下:
var fullscreenElement =
document.fullscreenEnabled
|| document.mozFullscreenElement
|| document.webkitFullscreenElement;
var fullscreenEnabled =
document.fullscreenEnabled
|| document.mozFullscreenEnabled
|| document.webkitFullscreenEnabled;

澳门葡京,在起头化全屏方法时,能够探测需要监听哪一个事件.

Fullscreen CSS

浏览器提供了部分立竿见影的 fullscreen CSS 控制规则:

代码如下:
/* html */
:-webkit-full-screen {
/* properties */
}
:-moz-fullscreen {
/* properties */
}

:fullscreen {
/* properties */
}

/* deeper elements */
:-webkit-full-screen video {
width: 100%;
height: 100%;
}

/* styling the backdrop */
::backdrop {
/* properties */
}

在一些情形下,Web基特(Kit)需要有的非同平日处理,所以在拍卖多媒体时,你恐怕需要地点的代码。

自己觉得 Fullscreen API 一级简单,一流有用. 我第一次看到那一个 API 是在一个名为
MDN’s BananaBread demo 的全客户端第一人称射击游戏,
这真是一个应用全屏形式的绝佳案例。

全屏API提供了进去和剥离全屏形式的办法,并提供相应的事件来监测全屏状态的变动,所以各地点都连贯起来了.

请牢记这一个很好的API吧 —— 在以后的某个时刻,它必将会派上用场!

这篇著作重要介绍了HTML5全屏(Fullscreen)API详细介绍,本文给出了启动全屏情势和退出全屏格局代码…

HTML5提供了部分老大强劲的JavaScript和HTML
API,来支援开发者构建非凡的桌面和活动应用程序。本文将介绍5个流行的API,希望对你的开支工作有着帮忙。

一、video的js知识点:

 

controls(控制器)、autoplay(自动播放)、loop(循环)==video默认的;

  1.  全屏API(Fullscreen API)

自定义播放器中部分JS中提供的办法和总体性的笔录:

 

1、play()控制视频的播报

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

2、pause()控制录像的平息

 

3、current提姆(Tim)e控制视频的眼前天子

 

4、muted控制视频是否静音(赋值true or false)

//

5、volume控制音量的大小(赋值0-1)

 找到适合浏览器的全屏方法

6、duration视频的总时间

 

7、ontimeupdate事件(当前播报地方变动时实施,使用时要绑定add伊夫(Eve)ntListener)

function

8、requestFullscreen全屏

 

二、全屏API介绍

launchFullScreen(element) {

浏览器全屏API简史

 

1、第一个落实浏览器原生全屏API的是在Safari
5.0(和iOS)中增长的webkitEnterFullScreen()函数,但是它不得不在Safar的<video>标签的controls中。

  if(element.requestFullScreen)

2、在Safari
5.1中,苹果更新了这么些API使它更接近于Mozilla的全屏API草案(实际上这要比苹果实现的更早),现在,所有的DOM元素都足以调用webkitRequestFullScreen()函数使HTML页面进入到全屏格局。

 {

3、Firefox和Chome发表它们将会加上原生的全屏API帮助,而且以此特性已经在Chome
15+以及Firefox10+中落实,Mozilla团队现已通知了一些。

 

4、在二〇一一年一月15日,W3C发表了一份全屏API草案(由Opera团队的一名成员编写),它跟Mozilla的草案有三个首要的不同点:

    element.requestFullScreen();

  1. Mozilla/Webkit使用大写字母’S’(FullScreen),但W3C则不是(Fullscreen)
  2. Mozilla/Webkit使用cancelFullScreen,W3C使用exitFullscreen

 

5、更新 (11/15/2011):来自IEBlog的Ted
Johnson说IE10将不会支持全屏API (12/05/2011:
我对Ted的首先封email领会错了)IE10的开支团队还尚无决定是否要促成全屏API。但是,他提出:Win8的
Metro风格的Internet
Explorer始终是全屏状态,正如以前那么,按F11键即可进入全屏模式。

  }

浏览器全屏API

else

要进来全屏格局,可以调用需要进入全屏元素的requestFullScreen(或者W3C的
requestFullscreen)方法。。要剥离全屏,则调用document对象的cancelFullScreen(或者W3C的exitFullscreen)方法。

 

代码:

if(element.mozRequestFullScreen)

全屏

 {

var docElm = document.documentElement;
//W3C
if(docElm.requestFullscreen){

 

docElm.requestFullscreen();

    element.mozRequestFullScreen();

}
//FireFox
else if (docElm.mozRequestFullScreen) {

 

docElm.mozRequestFullScreen();

  }

}
//Chrome等
else if (docElm.webkitRequestFullScreen) {

else

docElm.webkitRequestFullScreen();

 

}
//IE11
else if (elem.msRequestFullscreen) {

if(element.webkitRequestFullScreen)

elem.msRequestFullscreen();

 {

}

 

退出全屏

    element.webkitRequestFullScreen();

if (document.exitFullscreen) {

 

document.exitFullscreen();

  }

}

 

else if (document.mozCancelFullScreen) {

}

document.mozCancelFullScreen();

 

}

  

else if (document.webkitCancelFullScreen) {

 

document.webkitCancelFullScreen();

//

}

 启动全屏形式

else if (document.msExitFullscreen) {

 

document.msExitFullscreen();

launchFullScreen(document.documentElement);

}

//

监听是否全屏

 the whole page

document.addEventListener(“fullscreenchange”, function(){

 

fullscreenState.innerHTML = (document.fullscreen)? “” : “not “;},
false);

launchFullScreen(document.getElementById(“videoElement”));

document.addEventListener(“mozfullscreenchange”, function () {

//

fullscreenState.innerHTML = (document.mozFullScreen)? “” : “not “;},
false);

 any individual element

document.addEventListener(“webkitfullscreenchange”, function () {

  教程 / 演示

fullscreenState.innerHTML = (document.webkitIsFullScreen)? “” : “not
“;}, false);

 

document.addEventListener(“msfullscreenchange”, function () {

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

fullscreenState.innerHTML = (document.msFullscreenElement)? “” : “not
“;}, false);

 

全屏是的体裁设置

  该API可以用来检测页面对于用户的可见性,即重回用户眼前浏览的页面或标签的处境变化。

html:-moz-full-screen {
background: red;
}
html:-webkit-full-screen {
background: red;
}
html:fullscreen {
background: red;
}

 

https://www.cnblogs.com/duanlianjiang/p/5557015.html

 

//

 设置隐藏属性和可见改变事件的称呼,属性需要加浏览器前缀

 

//

 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);

  教程 / 演示

 

  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(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);

  教程 / 演示

 

  4.  电池API(Battery API)

 

  这是一个针对性移动设备应用程序的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);

  教程

 

  5.  Link Prefetching

 

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

 

 

<!–

 full page –>

 

<link

 

rel=”prefetch”

 

href=””

 

/>

 

  

 

<!–

 just an image –>

 

<link

 

rel=”prefetch”

 

href=”

 

/>

API,来救助开发者构建非凡的桌面和活动应用程序。本文将介绍5个流行的API,希望对你的支付工作…

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website