jquery - 当用户切换选项卡时暂停 html5 视频

标签 jquery html video html5-video

我的网页上嵌入了 HTML5 视频:

<video id="myvideo">
    <source src="videos/myvideo.mp4">
</video>

当用户转到不同的浏览器窗口或选项卡时,我有一些 jQuery 可以暂停视频。并在用户返回时播放视频:

// pause when the user leaves this window/tab
$(window).blur(function(){
    $('#myvideo').get(0).pause();
});

// play when the user returns to this window/tab
$(window).focus(function(){
    $('#myvideo').get(0).play();
});

这样做的问题是,如果用户单击地址栏或关注不同的操作系统窗口,即使视频可见并且用户没有切换选项卡,视频也会暂停。

有没有办法根据当前选项卡是否打开(但不一定聚焦)来暂停/播放视频?

最佳答案

我在发布问题后几乎立即找到了答案。 Page Visibility API允许您知道网页何时可见或处于焦点状态。有一个很好的 jQuery shim 叫做 jquery-visibility为跨浏览器解决方案提供了干净的 API。使用它你可以做类似的事情:

$(document).on('show.visibility', function() {
    $('#myvideo').get(0).play();
});
$(document).on('hide.visibility', function() {
    $('#myvideo').get(0).pause();
});

关于jquery - 当用户切换选项卡时暂停 html5 视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28033359/

相关文章:

javascript - Jquery如何指定哪个droppable应该与嵌套的droppable元素一起使用

javascript - 无法使用 :not() 将按钮定位为分离行为

javascript - 如何在段落中四舍五入到最接近的小数?

Android,如何将视频转换为慢动作并使用 FFmpeg 以慢动作播放

jquery - 使用 jQuery 和绝对定位的 div 用于下拉菜单。当光标仍在 div 上时停止隐藏菜单

jquery - 使用循环对用作选择器的数组执行操作

javascript - 用户可以使用控制台在我的网站上发送无效投注

javascript - 如何使用 JavaScript 设置多项选择的值

video - 如何像 Firefox 页面一样嵌入视频?

nginx - ffmpeg 转码到 youtube 直播坏视频容器