在 「小程序」 中怎麼實現這種橫向滾動效果呢。css
提及來也簡單,直接上代碼吧html
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> 複製代碼
.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; } 複製代碼
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 }) }, 複製代碼