如何使用html5的Page Visibility API来实现获取焦点js事件


本文摘自PHP中文网,作者伊谢尔伦,侵删。

当前窗口获得焦点js事件,html5发布之前我们使用window.onfocus和window.onblur来获得窗口焦点和失去窗口焦点

1

2

3

4

5

6

7

8

9

//当前窗口得到焦点

window.onfocus = function() {

  //播放动画或视频

};

  

//当前窗口失去焦点

window.onblur = function() {

  //暂停动画或视频

};

这个方法可以实现切换标签暂停动画视频,但是会带来一个问题,由于是判断焦点,如果是在当前页面上铺上一个小窗口,那当前页面就暂停了动画,试想,如果你一边看片,一边开个聊天窗口与MM聊天,当你操作聊天窗口的时候,视频暂停了,这并不是你想要的效果。

现在我们来看看HTML5是怎么解决的。H5 提供了很多简单实用的 API,Page Visibility API 就是其中之一。 Page Visibility API能有效的帮助我们完成这样的判断。

使用html5的Page Visibility API来实现

这个 API 本身非常简单,由以下三部分组成。

document.hidden:表示页面是否隐藏的布尔值。页面隐藏包括 页面在后台标签页中 或者 浏览器最小化 (注意,页面被其他软件遮盖并不算隐藏,比如打开的 sublime 遮住了浏览器)。

document.visibilityState:表示下面 4 个可能状态的值

hidden:页面在后台标签页中或者浏览器最小化

visible:页面在前台标签页中

prerender:页面在屏幕外执行预渲染处理 document.hidden 的值为 true

unloaded:页面正在从内存中卸载

Visibilitychange事件:当文档从可见变为不可见或者从不可见变为可见时,会触发该事件。

这样,我们可以监听 Visibilitychange 事件,当该事件触发时,获取 document.hidden 的值,根据该值进行页面一些事件的处理。

1

2

3

4

5

6

7

8

document.addEventListener('visibilitychange', function() {

  var isHidden = document.hidden;

  if (isHidden) {

    // 动画视频暂停

  } else {

    // 动画视频开始

  }

});

结合demo中的实例,切换标签或者最小化的时候,demo中的视频会暂停,恢复当前页面时,demo中的视频会继续播放。完整的代码如下:

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

var videoElement = document.getElementById("videoElement");

  

// 如果页面被隐藏,则暂停播放,如果页面恢复,则继续播放

function handleVisibilityChange() {

  if (document[hidden]) {

    videoElement.pause();

  } else {

    videoElement.play();

  }

}

  

// 判断浏览器的支持情况

if (typeof document.addEventListener === "undefined" || typeof document[hidden] === "undefined") {

  consol.log("This demo requires a browser, such as Google Chrome or Firefox, that supports the Page Visibility API.");

} else {

  // 监听visibilityChange事件   

  document.addEventListener(visibilityChange, handleVisibilityChange, false);

      

  // 当播放器暂停的时候,将页面标题设置为:Paused.

  videoElement.addEventListener("pause", function(){

    document.title = 'Paused';

  }, false);

      

  // 当播放器正常播放时,将页面标题设置为:Playing.

  videoElement.addEventListener("play", function(){

    document.title = 'Playing'

  }, false);

}

以上就是如何使用html5的Page Visibility API来实现获取焦点js事件的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

npm机制深入理解

HTML5中postmessage api的基本使用

HTML5编程实战之三-图片文本(txt)拖拽预览实现代码

http协议发展过程一览

h5中怎样使用postmessage实现两个网页间传递数据

如何通过display或visibility来实现html元素的显示与隐藏

详细介绍HTML5中的新事件

关于HTML5如何在canvas中插入图片的示例详解

HTML5中返回音频/视频是否已暂停的属性paused

HTML5 video怎么停止播放视频

更多相关阅读请进入《HTML5》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...