javascript - Swiper滑块过渡错误
问题描述
我正在尝试使用 vueawesome 滑块(基于 swiper 滑块)制作滑块。我试图让它看起来像这样
但是由于某种原因,当滑动器经过第一个循环时从第一个元素转到第二个元素时,动画不起作用。
过渡不是无缝的,它只是瞬间的。如果我删除所有自定义转换的东西并让它使用正常的 300 毫秒它工作正常。我完全不知道如何使它工作,我什至尝试使用coverflow效果但无济于事。我还尝试将动画放在内部容器而不是幻灯片元素本身上,但由于某种原因这也不起作用。
模板:
<swiper :options="swiperOption" ref="mySwiper">
<!-- slides -->
<swiper-slide class="swiper-1">
<div class="inner">
HELLOW 1
</div>
</swiper-slide>
<swiper-slide>
<div class="inner">
HELLOW 2
</div>
</swiper-slide>
<swiper-slide>
<div class="inner">
HELLOW 3
</div>
</swiper-slide>
<!-- Optional controls -->
<div class="swiper-pagination" slot="pagination"></div>
</swiper>
刷卡选项:
swiperOption: {
loop: true,
grabCursor: false,
slidesPerView:'auto',
centeredSlides: true,
autoplay: {
delay: 2500,
disableOnInteraction: false,
},
}
当前样式:
.swiper-container {
width: 100%;
height: calc(100vh - 66px);
padding-top: 100px;
padding-bottom: 100px;
}
.swiper-slide {
text-align: center;
font-size: 18px;
background: #fff;
display: -webkit-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
-webkit-box-pack: center;
-ms-flex-pack: center;
-webkit-justify-content: center;
justify-content: center;
-webkit-box-align: center;
-ms-flex-align: center;
-webkit-align-items: center;
align-items: center;
width:80% !important;
transform: scale(.8) !important;
transition: all 1500ms cubic-bezier(.85,1.54,.97,1.07) !important;
}
.swiper-slide.swiper-slide-active{
transform: scale(1) !important;
}
.swiper-slide .inner{
background:blue;
width:100%;
height:100%;
}
谁知道如何解决我的问题?
编辑当我尝试拖动滑动器以转到下一个滑块时,第一张幻灯片上出现了一个问题,它播放了两次过渡。
现场演示:这里(向下滚动通过标题)
先谢谢啦~
解决方案
我刚才遇到了同样的问题。经过一番研究,我发现这个解决方案可以解决我的问题。您还必须将 CSS 效果应用于活动的复制幻灯片。
所以这可能会解决你的问题:
.swiper-slide.swiper-slide-active,
.swiper-slide.swiper-slide-duplicate-active{
transform: scale(1) !important;
}