您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關微信小程序如何實現錨點定位功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在小程序開發(fā)中,我們經常會遇到滾動列表查看的需求,那么使用錨點定位來實現可以達到交互體驗更加友好的效果,我們看下項目中實現的效果:
采用小程序視圖容器組件實現:scroll-view
這里需要注意的是,豎向滾動時,scroll-view需要指定一個固定高度,我們看下WXML代碼:
<scroll-view scroll-y scroll-into-view="{{toView}}" class="scroll-warp" scroll-with-animation="{{true}}" bindscroll="handelScroll"> <block wx:for="{{dataList}}" wx:key="{{index}}"> <view class="floorType" id="{{item.floor}}"> </view> </block> </scroll-view>
這里autoHeight是根據不同機型的高度動態(tài)計算出來的,scroll-view有個重要屬性:scroll-into-view,它接收一個string值,即為滾動的地點(錨點),那么我們需要在scroll-view子節(jié)點也設置相應的錨點列表:如上圖的class=floorType節(jié)點中的id屬性。這樣我們的滾動就有了一一對應的關系了,在篩選塊點擊樓層,將toView變量設置成對應的數據,列表也會滾動到對應的位置。
當我們滾動列表的時候,頂部的高亮篩選項也需要對應切換,那這個時候怎么辦呢?
我們可以在bindscroll此事件上做文章:滾動列表的時候會觸發(fā)此事件。
關鍵代碼:
handelScroll(e) { let scrollTop=e.detail.scrollTop; let scrollArr= this.data.anchorArray; if(scrollTop>=scrollArr[scrollArr.length-1]-this.data.autoHeight){ return; }else { for(let i=0;i<scrollArr.length;i++){ if(scrollTop>=0&&scrollTop<scrollArr[0]){ // selectFloorIndex控制篩選塊高亮顯示 this.setData({ selectFloorIndex: 0 }); }else if(scrollTop>=scrollArr[i-1]&&scrollTop<scrollArr[i]) { this.setData({ selectFloorIndex: i }); } } } }
這里的anchorArray為所有錨點塊所占頁面高度的數組總和,用圖可以看得更加清晰一點:
每個錨點塊都有一個固定的高度,我們在拿到數據渲染完頁面后,可以通過
boundingClientRect方法拿到類名為floorType各個節(jié)點的高度,并將這些高度裝進anchorArray數組中,那么當我們滾動超過某塊錨點高度之后,頂部篩選項也會隨之切換到下一個。
關鍵代碼:
let query = wx.createSelectorQuery().in(this); let heightArr =[]; let h = 0; query.selectAll('.floorType').boundingClientRect((react)=>{ react.forEach((res)=>{ h+=res.height; heightArr.push(h) }) this.setData({ anchorArray:heightArr }); }).exec();
關于“微信小程序如何實現錨點定位功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。