- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > web開(kāi)發(fā) > JavaScript >
- 微信小程序實(shí)現錨點(diǎn)定位功能的方法實(shí)例
在小程序開(kāi)發(fā)中,我們經(jīng)常會(huì )遇到滾動(dòng)列表查看的需求,那么使用錨點(diǎn)定位來(lái)實(shí)現可以達到交互體驗更加友好的效果,我們看下項目中實(shí)現的效果:
采用小程序視圖容器組件實(shí)現:scroll-view
這里需要注意的是,豎向滾動(dòng)時(shí),scroll-view需要指定一個(gè)固定高度,我們看下WXML代碼:
<scroll-view style="height:{{autoHeight}};" 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是根據不同機型的高度動(dòng)態(tài)計算出來(lái)的,scroll-view有個(gè)重要屬性:scroll-into-view,它接收一個(gè)string值,即為滾動(dòng)的地點(diǎn)(錨點(diǎn)),那么我們需要在scroll-view子節點(diǎn)也設置相應的錨點(diǎn)列表:如上圖的class=floorType節點(diǎn)中的id屬性。這樣我們的滾動(dòng)就有了一一對應的關(guān)系了,在篩選塊點(diǎn)擊樓層,將toView變量設置成對應的數據,列表也會(huì )滾動(dòng)到對應的位置。
當我們滾動(dòng)列表的時(shí)候,頂部的高亮篩選項也需要對應切換,那這個(gè)時(shí)候怎么辦呢?
我們可以在bindscroll此事件上做文章:滾動(dòng)列表的時(shí)候會(huì )觸發(fā)此事件。
關(guān)鍵代碼:
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為所有錨點(diǎn)塊所占頁(yè)面高度的數組總和,用圖可以看得更加清晰一點(diǎn):
每個(gè)錨點(diǎn)塊都有一個(gè)固定的高度,我們在拿到數據渲染完頁(yè)面后,可以通過(guò)
boundingClientRect方法拿到類(lèi)名為floorType各個(gè)節點(diǎn)的高度,并將這些高度裝進(jìn)anchorArray數組中,那么當我們滾動(dòng)超過(guò)某塊錨點(diǎn)高度之后,頂部篩選項也會(huì )隨之切換到下一個(gè)。
關(guān)鍵代碼:
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();
到這里,我們的錨點(diǎn)定位滾動(dòng)已完成,希望能對大家有所幫助,如有問(wèn)題,歡迎溝通指出!
到此這篇關(guān)于微信小程序實(shí)現錨點(diǎn)定位功能的文章就介紹到這了,更多相關(guān)微信小程序錨點(diǎn)定位內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站