我有一个简单的Bootstrap Carousel,其中包含一个视频。
这是我的演示:http://jsfiddle.net/Q2TYv/2053/
单击视频上的“播放”时,是否可以暂停滑块?目前,当我单击Play
时,它仍会自动播放其余轮播项目。**
感谢您的任何建议。
// invoke the carousel
$('#myCarousel').carousel({
interval: 3000
});
/* SLIDE ON CLICK */
$('.carousel-linked-nav > li > a').click(function() {
// grab href, remove pound sign, convert to number
var item = Number($(this).attr('href').substring(1));
// slide to number -1 (account for zero indexing)
$('#myCarousel').carousel(item - 1);
// remove current active class
$('.carousel-linked-nav .active').removeClass('active');
// add active class to just clicked on item
$(this).parent().addClass('active');
// don't follow the link
return false;
});
/* AUTOPLAY NAV HIGHLIGHT */
// bind 'slid' function
$('#myCarousel').bind('slid', function() {
// remove active class
$('.carousel-linked-nav .active').removeClass('active');
// get index of currently active item
var idx = $('#myCarousel .item.active').index();
// select currently active item and add active class
$('.carousel-linked-nav li:eq(' + idx + ')').addClass('active');
});
@import url('//netdna.bootstrapcdn.com/twitter-bootstrap/2.0.4/css/bootstrap-combined.min.css');
#myCarousel {
margin-top: 40px;
}
.carousel-linked-nav,
.item img {
display: block;
margin: 0 auto;
}
.carousel-linked-nav {
width: 120px;
margin-bottom: 20px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.0.4/js/bootstrap.min.js"></script>
<div id="myCarousel" class="carousel slide">
<!-- Carousel items -->
<div class="carousel-inner">
<div class="active item">
<img src="http://placehold.it/300x200/444&text=Item 1" />
</div>
<div class="item">
<iframe src="https://player.vimeo.com/video/124400795"></iframe>
</div>
<div class="item">
<img src="http://placehold.it/300x200/444&text=Item 3" />
</div>
</div>
<!-- Carousel nav -->
<a class="carousel-control left" href="#myCarousel" data-slide="prev">‹</a>
<a class="carousel-control right" href="#myCarousel" data-slide="next">›</a>
</div>
<!-- LINKED NAV -->
<ol class="carousel-linked-nav pagination">
<li class="active"><a href="#1">1</a></li>
<li><a href="#2">2</a></li>
<li><a href="#3">3</a></li>
</ol>
最佳答案
编辑:
抱歉,由于与iframe的同源政策,我首先在下面发布的解决方案无法正常工作(请参见here)。
所以-使用该文章中提到的解决方案-这是一个更精细的解决方案:
var overiFrame = false;
$('#myCarousel iframe').hover( function() {
overiFrame = true;
}, function() {
overiFrame = false;
});
$(window).blur( function() {
if(overiFrame){
$('#myCarousel').carousel('pause');
}
});
这不是出于相同起源的政策:
$('#myCarousel .item iframe').on('click', function(){
$('#myCarousel').carousel('pause');
});
最好的解决方案可能是实现vimeo JS API并使用它在视频上注册PLAY和PAUSE事件,而没有上述任何黑客手段。