van-swipe__track------Vant轮播图使用时遇到的一个坑

在做仿网易云移动端Vue项目时,有一个手动拖动轮播图切换展示图片和文字的需求。于是,我就使用了vant组件库里的Swipe轮播组件来做,选取了自定义滑块的代码。(下面为模板代码)

<van-swipe :loop="false" :width="300">
  <van-swipe-item>1</van-swipe-item>
  <van-swipe-item>2</van-swipe-item>
  <van-swipe-item>3</van-swipe-item>
  <van-swipe-item>4</van-swipe-item>
</van-swipe>

用Swipe轮播组件设置好样式后的效果:

但是,当我设置好图片和文本样式后,我发现拖动轮播图到底部无法显示完整的数据,只能显示到倒数第二个数据,而且图片还不完整,有一部分未显示。

也就是说,总共10组数据,但轮播图只给我显示了9组,而且显示不完整。

那问题出在了哪?

 

一开始,我审查页面的DOM元素,发现了van-swipe__track宽度只有1500px,于是我就觉得是轮播图的容器宽度不够,从而无法展示所有数据。然后,我就想着改大它的宽度,但无论我怎么尝试都无法修改van-swipe__track的宽度,它始终是1500px。

后来,我静下心想了下上面另一个轮播图组件的van-swipe__track宽度又是另外一个数值,那这里的1500px到底是怎么定义出来的?

突然,我想到了问题所在。每组数据显示的滑块我给设置的宽度是150px,所以van-swipe__track的宽度1500px显然就是10组滑块的累加,正常情况下是能刚好装下所有滑块。但是,我之前给每组滑块添加了左右的margin值,使得这个1500px的容器装不下被撑大且宽度不止150px的滑块。如此简单的问题,困扰了我许久。

所以解决办法就是,把margin换成padding来充当间隔效果,再把滑块的自定义宽度改成170px(因为我是在全局设置了怪异盒模型,如果没设置的话,自定义宽度还是150px即可)

解决问题后的效果图:

 

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 25
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值