在我的网站上有包含许多视频的页面。 iframe视频在视口中完全可见时,视频应自动播放。当视频移动到视口上方时,视频应该像我们在Facebook中看到的那样暂停。
注意:我使用的是iframe
,但没有使用html5
视频元素。
答案 0 :(得分:2)
虽然SO不是请求代码的地方,但我会因为挑战和其他需要这个想法的人而回答这个问题。
所以,我正在使用jquery.inview
插件来检测iframe何时在视口中。
另外,我正在使用youtube api
来控制视频的iframe。
要解释每行的工作方式并不容易,所以请阅读代码,如果您有问题,请发表评论。
以下是完整代码(由于安全原因,不在此网站上工作,因此您可以看到http://output.jsbin.com/soqezo中的实时内容)
// Inject YouTube API script
var tag = document.createElement('script');
tag.src = "//www.youtube.com/player_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var players = [];
function onYouTubePlayerAPIReady() {
$('iframe').each(function() {
var ifr = $(this),
player = new YT.Player(ifr[0].id);
ifr.data('player', player);
players.push(player);
});
initInView();
}
function pausePlayers() {
for (var i in players) {
players[i] && players[i].pauseVideo && players[i].pauseVideo();
}
}
function initInView() {
$('div').each(function() {
$(this).on('inview', function(event, isInView) {
if (isInView) {
// element is now visible in the viewport
pausePlayers();
var player = $(this).find('iframe').data('player');
if (player) {
player.playVideo && player.playVideo();
}
} else {
// element has gone out of viewport
//$(this).find('iframe').data('player').pauseVideo();
}
});
});
}
html, body, div {
height:100%;
}
div {
width:100%;
height:100%;
background:red;
margin-bottom:100px;
}
iframe {
width:100%;
height:100%;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.jsdelivr.net/jquery.inview/0.2/jquery.inview.min.js"></script>
<div>
<iframe src="//www.youtube.com/embed/FKWwdQu6_ok?enablejsapi=1" frameborder="0" allowfullscreen id="video1"></iframe>
</div>
<div>
<iframe src="//www.youtube.com/embed/FKWwdQu6_ok?enablejsapi=1" frameborder="0" allowfullscreen id="video2"></iframe>
</div>
<div>
<iframe src="//www.youtube.com/embed/FKWwdQu6_ok?enablejsapi=1" frameborder="0" allowfullscreen id="video3"></iframe>
</div>
<div>
<iframe src="//www.youtube.com/embed/FKWwdQu6_ok?enablejsapi=1" frameborder="0" allowfullscreen id="video4"></iframe>
</div>
<div>
<iframe src="//www.youtube.com/embed/FKWwdQu6_ok?enablejsapi=1" frameborder="0" allowfullscreen id="video5"></iframe>
</div>
答案 1 :(得分:1)
使用
可以达到同样的效果iframe.contentWindow.postMessage(message, origin);
不使用YouTube的播放器API。查看下面的链接,了解现场演示:
https://codepen.io/mcakir/pen/JpQpwm
注意:现场演示支持播放/暂停来自 Youtube,vimeo和dailymotion 的iframe视频(不久将添加更多内容),而无需使用任何播放器的库或SDK