随笔 - 419  文章 - 3  评论 - 331  阅读 - 120万

Swiper 实现奇葩需求案例

昨天晚上临时接到一个奇葩需求,有一个从左到右的滚动列表,要求实现开屏自动滚动,然后到最后一屏的时候停止不动,右箭头置灰,然后点左侧箭头可以往左滚,同时右箭头功能也恢复。

使用 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 的功能实在是太牛了,好多参数仔细研究下还是很有用的。

posted on   JoeYoung  阅读(21)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· [翻译] 为什么 Tracebit 用 C# 开发
· 腾讯ima接入deepseek-r1,借用别人脑子用用成真了~
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· DeepSeek崛起:程序员“饭碗”被抢,还是职业进化新起点?
· RFID实践——.NET IoT程序读取高频RFID卡/标签
历史上的今天:
2019-12-04 Flutter中的日期插件date_format 中文 国际化 及flutter_cupertino_date_picker
< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

点击右上角即可分享
微信分享提示