滑动滑块转到第一张幻灯片

时间:2016-06-23 08:38:37

标签: jquery slick.js

“滑动”滑块设置为自动播放。在比赛时,幻灯片从左到右或从头到尾。当最后一张幻灯片到达滑块时,它会从最后一张幻灯片开始自动播放,然后向后滑动。

我想在最后一张幻灯片到达滑块时从第一张幻灯片播放滑块而不是最后一张幻灯片。

最初当无限卷轴是真的时候,一切都运转正常。 但由于要求,我必须将无限滚动设置为“假”。当无限滚动设置为' false'

时,会出现上述问题

当滑块到达最后一张幻灯片时,我设法显示警告。我想要做的是当滑块到达最后一张幻灯片时,我想转到第一张幻灯片,而不是显示警告。

这是Fiddle



$(document).ready(function() {

var slider2 = $('.slider-2').slick({
    dots: true,
    infinite: false,
    autoplay: true,
    autoplaySpeed: 1000,
    pauseOnFocus: false,
    pauseOnHover: false,
    pauseOnDotsHover: false,
    slidesToShow: 1,
    slidesToScroll: 1,
    fade: true,
    cssEase: 'linear'
});

slider2.on('afterChange', function(event, slick, currentSlide){
// slick - is a slider object with a lot of useful info
// currentSlide - is a current slide index (starts from 0)
if( slick.slideCount === currentSlide + 1 ){
     alert('Instead of showing alert goto slide 1.');
}
});

});

<link href="https://kenwheeler.github.io/slick/slick/slick-theme.css" rel="stylesheet"/>
<link href="https://kenwheeler.github.io/slick/slick/slick.css" rel="stylesheet"/>
<link href="https://kenwheeler.github.io/slick/css/prism.css" rel="stylesheet"/>
<link href="https://kenwheeler.github.io/slick/css/style.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
<script src="https://kenwheeler.github.io/slick/slick/slick.js"></script>
<style>
.slick-arrow.slick-disabled {
    display: none !important;
}
</style>
<section id="features" class="blue">
<div class="content">
  <div class="slider slider-2">
    <div><h3>1</h3></div>
    <div><h3>2</h3></div>
    <div><h3>3</h3></div>
    <div><h3>4</h3></div>
    <div><h3>5</h3></div>
    <div><h3>6</h3></div>
    <div><h3>7</h3></div>
    <div><h3>8</h3></div>
  </div>
</div>
</section>
&#13;
&#13;
&#13;

如果有人有解决方案/建议,请帮忙。 提前谢谢。

1 个答案:

答案 0 :(得分:3)

正如其他评论者指出的那样,如果infinite设置为false,您将无法转到第一张幻灯片。在您的评论中,您提到您不希望在第一张幻灯片上显示左箭头,在最后一张幻灯片上显示右箭头。您可以通过监视currentSlide并隐藏/显示箭头按钮来实现这一点。

slider2.on('afterChange', function(event, slick, currentSlide) {
  //If we're on the first slide hide the Previous button and show the Next
  if (currentSlide === 0) {
    $('.slick-prev').hide();
    $('.slick-next').show();
  } else {
    $('.slick-prev').show();
  }

  //If we're on the last slide hide the Next button.
  if (slick.slideCount === currentSlide + 1) {
    $('.slick-next').hide();
  }
});

Updated Fiddle

slickGoTo函数,但如果在afterChange事件处理程序中使用,则无效。