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 的功能实在是太牛了,好多参数仔细研究下还是很有用的。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· [翻译] 为什么 Tracebit 用 C# 开发
· 腾讯ima接入deepseek-r1,借用别人脑子用用成真了~
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· DeepSeek崛起:程序员“饭碗”被抢,还是职业进化新起点?
· RFID实践——.NET IoT程序读取高频RFID卡/标签
2019-12-04 Flutter中的日期插件date_format 中文 国际化 及flutter_cupertino_date_picker