解决在vue中使用swiper loop失效的问题

Others 2019-10-26 08:09:53 2019-10-26 08:09:53 1904 次浏览

1.初始化完成后 swiper 轮播出现问题1:不能自动切换

1)问题产生原因:

axios 执行get指令是异步请求 

即在axios请求数据过程中 initSwiper运行时要绑定的部分元素节点还没有创建成功

导致swiper插件中部分指定并没有绑定到指定元素节点上

导致swiper轮播出现异常

2)解决方法: 

swiper中的observer方法,在启动状态下,当我们修改swiper的子元素时,会自动初始化swiper

即  observer:true, 

并该指令一般情况下搭配 observeParents:true,一起使用 即当Swiper的父元素变化时,会更新swiper

3) 更改部分:

增加 observer: true, observeParents: true,

2.更改完成后 swiper 轮播出现问题2:切换到最后一张即停止

1)问题原因:

在jQuery中 当得到数据时,是边加载边更新Dom

但是在Vue中 当得到数据时, 而是全部加载完以后再更新Dom

即在这个问题中, initSwiper运行完之后,axios请求到的数据才加载完并更新Dom

在一开始容器中的数据并没有渲染 此时swiperOption配置的loop: true不生效

而即使swiper更新 而loop属性却并不会重新加载 即loop为false

2)解决方法:

方法① 给initSwiper添加定时器 即等到axios数据加载完并渲染完页面以后再运行

添加定时器

但是在比较大的项目中,数据请求时间可能远远大于300ms 影响用户体验 所以不推荐使用

方法②不在created中调用initSwiper 而是在axios中调用initSwiper 

并且利用 setTimeout(()=>{ },0)的异步请求属性 即等待axios的get指令请求和渲染完 再执行。

利用setTimeout(()=>{},0)

方法③类似于方法②          

在vue中有Vue.nextTick( [callback, context] )机制 

即在下次 DOM 更新循环结束之后执行延迟回调。

即this.$nextTick(()=>{})

this.$nextTick(()=>{})

四.核心代码 

1.observer: true, observeParents: true,  

2.this.$nextTick(()=>{})

5人点赞
vue


链接:https://www.jianshu.com/p/f6d31e2732e0