jquery - 光滑的 slider 转到第一张幻灯片

标签 jquery slick.js

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

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

最初,当无限滚动为“true”时,一切都工作正常。 但由于要求,我不得不将无限滚动设置为“假”。当无限滚动设置为“false”时,会出现上述问题。

当 slider 到达最后一张幻灯片时,我设法显示一条警报。我想做的是,当 slider 到达最后一张幻灯片时,我想转到第一张幻灯片而不是显示警报。

这是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>

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

最佳答案

正如其他评论者所指出的,如果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 事件处理程序中使用,则该函数不起作用。

关于jquery - 光滑的 slider 转到第一张幻灯片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37986346/

相关文章:

jquery - jQuery 铁轨插件

javascript - jquery选择div索引

javascript - 在光滑的 slider 中仅禁用一次上一个箭头

css - 如何使用光滑的 slider 为 slider 图像添加慢速放大效果?

javascript - 顶部带有箭头的 React 水平滚动卡片

javascript - JQuery 对话框中的 Bootstrap Pills

javascript - 有没有方便的 html-parser 可以在 Nativescript 中使用

jquery - 使用 javascript 将 ID 分配给 DIV

javascript - 如何在 jquery 确认为定义后运行内联脚本