介绍
之前写过一篇swiper在react中的使用,里面介绍了@5.4.5
和@6.8.4
两个版本的swiepr。
里面也提到了一些常用的属性和方法。今天在项目中遇到个问题,
就是当swiper所在的页面,先隐藏,后显示,swiper就不工作了,自动播放不触发了。
于是,就打开swiper的官方api文档查看。发现了observer观察者模式。
这个模式就是用来监听swiper ,swiper的父元素 , swiper的子元素的,当这些元素发生了变化,
就会更新swiper。
比如,当页面在隐藏和显示之间进行切换时,会触发观察者模式,
然后更新swiper。此时,swiper中的属性,比如autoplay就会跟着触发。
场景再现
用个简略图来表示吧,这样应该会更直观一些。
点击tab1和tab2可以切换下面的content的content1和content2页面。
而swiper在其中一个页面里。切换页面就会引起swiper的隐藏和显示的切换。
这时如果不进行监测,swiper就会停止自动播放。
问题处理
打开swiper的api文档,就可以找到这个属性:
其中:
observer: 监听swiper
observeParents: 监听swiper的父元素们
observeSlideChildren: 监听slide
给swiper加上对应的监听,就可以正常播放了。
示例
export const SwiperComp = (props) => {
const { datas, texts } = props
return <Swiper
autoplay // 自动播放
loop // 循环播放
direction="vertical" // 上下滚动
observer // 监听swiper
observeParents // 监听swiper的父元素们
observeSlideChildren // 监听swiper中的slide
autoHeight // 高度自适应
>
{
datas && datas.map((item, index) => {
return <SwiperSlide key={index}>
恭喜<span>{item.userName}</span>{texts}<span>{item.awardName}</span>
</SwiperSlide>
})
}
</Swiper>
}