Swiper 實現奇葩需求案例

JoeYoung發表於2024-12-04

昨天晚上臨時接到一個奇葩需求,有一個從左到右的滾動列表,要求實現開屏自動滾動,然後到最後一屏的時候停止不動,右箭頭置灰,然後點左側箭頭可以往左滾,同時右箭頭功能也恢復。

使用 Swiper 實現了,示例程式碼如下:

html:

<link rel="stylesheet" href="https://unpkg.com/swiper@8/swiper-bundle.css">
<div class="swiper mySwiper">
    <div class="swiper-wrapper">
      <div class="swiper-slide">Slide 1</div>
      <div class="swiper-slide">Slide 2</div>
      <div class="swiper-slide">Slide 3</div>
      <div class="swiper-slide">Slide 4</div>
      <div class="swiper-slide">Slide 5</div>
      <div class="swiper-slide">Slide 6</div>
      <div class="swiper-slide">Slide 7</div>
      <div class="swiper-slide">Slide 8</div>
      <div class="swiper-slide">Slide 9</div>
    </div>
    <div class="swiper-button-next"></div>
    <div class="swiper-button-prev"></div>
</div>
<script type="text/javascript" src="/jquery/jquery.min.js"></script>
<script src="https://unpkg.com/swiper@8/swiper-bundle.js"> </script>  

css:

    html,
    body {
      position: relative;
      height: 100%;
    }
    body {
      background: #eee;
      font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
      font-size: 14px;
      color: #000;
      margin: 0;
      padding: 0;
    }
    .swiper {
      width: 100%;
      height: 100%;
    }
    .swiper-slide {
      text-align: center;
      font-size: 18px;
      background: #fff;
      display: flex;
      justify-content: center;
      align-items: center;
    }
    .swiper-slide img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

js:

var swiper = new Swiper(".mySwiper", {
      slidesPerView: 5,
      spaceBetween: 30,
      pagination: {
        el: ".swiper-pagination",
        clickable: true,
      },
      loop: false,
      autoplay: {
        delay: 3000,
        stopOnLastSlide: true, 
      },
      navigation: {
        nextEl: '.swiper-button-next',
        prevEl: '.swiper-button-prev',
      },
});

可以實現需求功能:slidesPerView 的引數值根據自己需求設定

然後最奇葩的需求出現了,要求:從最後一屏開始展示(就是開啟首屏顯示Slide5-9),左箭頭可以點選往左滾動,然後還可以自動滾動,直到最後一屏時還是停止不動。

當時就感覺瘋了,這是什麼奇葩需求。。。

仔細找了一下 Swiper 的引數,發現還真有可以實現的:initialSlide 屬性用於設定初始化時顯示的幻燈片索引‌

// 設定初始顯示的slide
initialSlide: $('.swiper-slide').length - 1, // 最後一個slide的索引

總結:

Swiper 的功能實在是太牛了,好多引數仔細研究下還是很有用的。

相關文章