最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 15:08:44
文档

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

如何使用html5的PageVisibilityAPI来实现获取焦点js事件:当前窗口获得焦点js事件,html5发布之前我们使用window.onfocus和window.onblur来获得窗口焦点和失去窗口焦点//当前窗口得到焦点 window.onfocus = function() { //播放动画或视频 }; //当前窗口失去焦点 window.onblur = functi
推荐度:
导读如何使用html5的PageVisibilityAPI来实现获取焦点js事件:当前窗口获得焦点js事件,html5发布之前我们使用window.onfocus和window.onblur来获得窗口焦点和失去窗口焦点//当前窗口得到焦点 window.onfocus = function() { //播放动画或视频 }; //当前窗口失去焦点 window.onblur = functi


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

//当前窗口得到焦点 
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 的值,根据该值进行页面一些事件的处理。

document.addEventListener('visibilitychange', function() { 
 var isHidden = document.hidden; 
 if (isHidden) { 
 // 动画视频暂停 
 } else { 
 // 动画视频开始 
 } 
});

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

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的PageVisibilityAPI来实现获取焦点js事件

如何使用html5的PageVisibilityAPI来实现获取焦点js事件:当前窗口获得焦点js事件,html5发布之前我们使用window.onfocus和window.onblur来获得窗口焦点和失去窗口焦点//当前窗口得到焦点 window.onfocus = function() { //播放动画或视频 }; //当前窗口失去焦点 window.onblur = functi
推荐度:
标签: js API 如何实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top