小程序swiper轮播返回数据变化是轮播不显示的问题

比如一开始轮播返回的数据是五条,轮播一段时间内,修改数据返回一条此时轮播不会显示。

原因是页面发生切换时,current 的值会被存储,也就是记住当前轮播的索引。再次返回会重新给current赋上当前存储的索引值。

比方:假设当前的图片是第4张,那么在未设置 current 的时候,框架会给 current 赋值 =3(对应索引),切换页面改变渲染的数组之后,如果该数组的长度是3,也就是最大 索引 = 2 ,框架还是会给默认的 current 赋值3(此时渲染swiper的img数组里根本没有索引为3的图片),没有找到就会导致元素为空,但是0-2的数据是存在的,所以页面会显示位置占位,但是这个占位得元素里没有内容

解决方法:在swiper标签中添加属性 curren 代码如下:
在这里插入图片描述
JS代码
在这里插入图片描述

这样就可以解决此问题了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
小程序swiper轮播图是一种常用的组件,用于展示多张图片或卡片。它可以实现自动播放、手动切换、循环播放等功能。在小程序中使用swiper组件,你可以通过以下步骤来实现轮播图: 1. 在小程序的wxml文件中添加swiper组件的标签,例如: ```html <swiper indicator-dots="{{indicatorDots}}" autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}"> <!-- swiper-item用于包裹每个轮播项 --> <swiper-item> <image src="{{imageUrls[0]}}"></image> </swiper-item> <swiper-item> <image src="{{imageUrls[1]}}"></image> </swiper-item> <!-- 更多swiper-item... --> </swiper> ``` 2. 在小程序的js文件中,定义swiper组件的相关属性和方法,例如: ```javascript Page({ data: { indicatorDots: true, // 是否显示指示点 autoplay: true, // 是否自动切换 interval: 5000, // 自动切换时间间隔 duration: 1000, // 滑动动画时长 imageUrls: [ 'https://example.com/image1.jpg', 'https://example.com/image2.jpg', // 更多图片URL... ] }, // 其他逻辑代码... }) ``` 在上述示例中,我们定义了indicatorDots、autoplay、interval等属性,可以根据需要进行配置。imageUrls是一个数组,包含了要展示的图片地址。你可以根据实际情况进行替换和扩展。 这样配置后,在小程序中就可以显示轮播图了。你可以根据需要自定义样式和交互效果,以及添加其他事件处理逻辑。希望能对你有所帮助!如果还有其他问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值