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

时间:2022-07-23
本文章向大家介绍小程序scroll-view点击项自动居中,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

效果

代码

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

<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轴距离,只要相减计算后的数值为正数,就可以证明上面的条件,触发滚动