Swiper:无限循环滚动时出现空白页/页面内容不刷新

问题描述

使用Swiper插件实现列表的无限循环滚动效果,记录遭遇的两个问题:①滚动到某页时界面显示空白;②用id唯一标识列表中需要动态改变的值,在改变某一id的div内容后,页面显示内容并未改变
使用Swiper无限循环滚动出现空白页
使用Swiper无限循环滚动界面数据不刷新

问题分析

使用开发者工具查看页面元素,可以看到Swiper复制了真实列表的第一页并插入列表尾部,同时复制了真实列表的最后一页并插入列表头部(用于实现无限循环滚动效果)
Swiper容器中实际多出两个页面

由此可以得出产生问题的原因:
①Swiper容器中实际存在的页面比真实页面多2页,若容器的高度(纵向滚动时)/宽度(横向滚动时)只按真实页面数量计算(即:小于实际需要的高度/宽度),会因显示不下而出现空白;
②Swiper复制的首末页将其中具有唯一id的div也一起复制了,所以首末页中的id其实并不唯一,根据id改变的div可能是没有显示出来的那个(首页/末页)页面中的,导致获取div值是新值而页面显示内容不变

总结

通过分析问题原因,可以很轻松地解决这两个问题啦:
①设置Swiper无限循环滚动时,要将Swiper容器的高度/宽度设置为能够多容纳2个页面的值;
②最好使用class标识需要动态改变值的div(哪怕这个标识是“唯一”的),这样所有具有这一class的div内容都会改变

参考文档

[1] Swiper官网

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值