首页 > 微信 > 详细

小程序scroll-view点击项自动居中

时间:2020-03-24 23:30:30      阅读:251      评论:0      收藏:0      [点我收藏+]

效果

技术分享图片

代码

布局样式代码省略,以下只展示逻辑代码

<scroll-view scroll-x scroll-left="{{scrollLeft}}" scroll-with-animation class="scroll-view">
  <view class="class-item" wx:for="{{classList}}" wx:key="id" bindtap="switchClass">
    <text class="name">{{item.className}}</text>
  </view>
</scroll-view>
onReady(){
  wx.createSelectorQuery().select(‘.scroll-view‘).boundingClientRect((rect)=>{
    this.data.scrollViewWidth = Math.round(rect.width)
  }).exec()
},
switchClass(){
  let offsetLeft = e.currentTarget.offsetLeft
  this.setData({
    scrollLeft: offsetLeft - this.data.scrollViewWidth/2
  })
}

我们想要的是居中的效果,所以触发滚动的条件是点scroll-view宽度一半之后的项才开始滚动,所以需要减去宽度的一半

offsetLeft为相对于scroll-view总长度的X轴距离,只要相减计算后的数值为正数,就可以证明上面的条件,触发滚动

小程序scroll-view点击项自动居中

原文:https://www.cnblogs.com/chanwahfung/p/12563035.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!