光滑的滑块转到第一张幻灯片

Slick slider goto first slide

Slick 滑块设置为自动播放。播放时,幻灯片从左到右或先到后。当滑块到达最后一张幻灯片时,它开始从最后一张幻灯片向后自动播放第一张幻灯片。

当滑块到达最后一张幻灯片时,我希望滑块从第一张幻灯片开始播放,而不是最后一张。

最初当无限滚动 'true' 时,一切正常。 但是由于需要,我不得不将无限滚动设置为'false'。无限滚动设置为'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>

如果有人有solution/suggestion,请帮忙。 提前致谢。

正如其他评论者指出的那样,如果 infinite 设置为 false,您将无法转到第一张幻灯片。在您的评论中,您提到您不想在第一张幻灯片上显示左箭头,在最后一张幻灯片上显示右箭头。您可以根据需要监视 currentSlide 和 hiding/showing 箭头按钮来实现。

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 事件处理程序中使用则该函数不起作用。