小程序實現自定義滾動條

小程序 中怎麼實現這種橫向滾動效果呢。css

提及來也簡單,直接上代碼吧html

1 .WXML

  • 分類區域使用小程序的scroll-view,綁定bindscroll事件,動態計算scroll-left的距離
  • 滾動條區域寫用兩個view模擬滾動條,滾動條的寬度和滾動距離都根據分類的內容來計算
<!-- 分類區域 -->
    <view class="scroll-wrap">
        <scroll-view scroll-x="true" scroll-with-animation="true" bindscroll="spikeScroll" class="scroll scroll-x" scroll-left="{{scrollLeft}}">
            <view class="scroll-item index-nav" wx:for="{{catList}}" wx:key="catId">
                <view class="index-nav-item flex-y-fs {{item.selected?'selected':''}}" data-idx="{{index}}" data-catid="{{item.catId}}" bindtap="handleClickCat">
                    <view class="cat-img-wrap">
                        <image class="" src="{{item.catPicUrl}}" mode=""></image>
                    </view>
                    <text>{{item.catName}}</text>
                </view>
            </view>
        </scroll-view>
    </view>
    <!-- 滾動條區域 -->
    <view class="scroll-bar">
        <view class="scroll-bar__bg">
        <view class="scroll-bar__slide" style="width: {{barW}}rpx;left:{{percent}}rpx"></view>
        </view>
    </view>
複製代碼

2 .CSS

.scroll-wrap {
  width: 100%;
  box-sizing: border-box;
  background: #ffffff;
}
.scroll {
  height: 100%;
  box-sizing: border-box;
}
.scroll-x {
  display: flex;
  width: 100%;
  white-space: nowrap;
  overflow-x: auto;
}
.scroll-item {
  width: 138rpx;
  display: inline-block;
  margin-right: 10rpx;
  padding: 0 24rpx 27rpx;
  font-size: 24rpx;
  color: #4e4e4e;
  font-family: PingFangSC-Regular, PingFang SC;
}
.scroll-bar {
  background: #ffffff;
}
.scroll-bar__bg {
  position: relative;
  width: 86rpx;
  height: 6rpx;
  background: #d4d8dd;
  border-radius: 5px;
  margin: 0 auto;
  overflow: hidden;
}
.scroll-bar__slide {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  background: rgba(233, 89, 14, 1);
  border-radius: 5px;
}
複製代碼

3 .JS

data: {
      percent: 0,       //滾動條距離左邊的距離
      barW: 0,          //滾動條的寬度
  }
/* 計算滾動區域的寬度 */
  countCatWidth () {
      var query = wx.createSelectorQuery();
      //選擇id
      var that = this;
      query.select('.scroll-item').boundingClientRect(function (rect) {
        let sw = (rect.width+5)*that.data.catList.length+5
        that.setData({
          barW: (86/sw)*wx.getSystemInfoSync().windowWidth
        })
      }).exec();
  },
  //bindscroll事件
  spikeScroll(e) {
      let barW = (86/e.detail.scrollWidth)*wx.getSystemInfoSync().windowWidth
      this.setData({
          barW: barW,
          percent: (86/e.detail.scrollWidth)*e.detail.scrollLeft
      })
  },
複製代碼
相關文章
相關標籤/搜索