swiper的动态观察者模式解决:swiper所在的页面先隐藏,后显示,swiper不自动播放了

swiper的动态观察者模式


介绍

之前写过一篇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>
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值