昨天晚上临时接到一个奇葩需求,有一个从左到右的滚动列表,要求实现开屏自动滚动,然后到最后一屏的时候停止不动,右箭头置灰,然后点左侧箭头可以往左滚,同时右箭头功能也恢复。
使用 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 的功能实在是太牛了,好多参数仔细研究下还是很有用的。