溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能

發(fā)布時(shí)間:2022-04-05 11:03:01 來源:億速云 閱讀:347 作者:iii 欄目:移動(dòng)開發(fā)

這篇“微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能”文章吧。

實(shí)現(xiàn)效果:

微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能            

功能實(shí)現(xiàn)

采用小程序視圖容器組件實(shí)現(xiàn):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是根據(jù)不同機(jī)型的高度動(dòng)態(tài)計(jì)算出來的,scroll-view有個(gè)重要屬性:scroll-into-view,它接收一個(gè)string值,即為滾動(dòng)的地點(diǎn)(錨點(diǎn)),那么我們需要在scroll-view子節(jié)點(diǎn)也設(shè)置相應(yīng)的錨點(diǎn)列表:如上圖的class=floorType節(jié)點(diǎn)中的id屬性。這樣我們的滾動(dòng)就有了一一對(duì)應(yīng)的關(guān)系了,在篩選塊點(diǎn)擊樓層,將toView變量設(shè)置成對(duì)應(yīng)的數(shù)據(jù),列表也會(huì)滾動(dòng)到對(duì)應(yīng)的位置。
當(dāng)我們滾動(dòng)列表的時(shí)候,頂部的高亮篩選項(xiàng)也需要對(duì)應(yīng)切換,那這個(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)塊所占頁面高度的數(shù)組總和,用圖可以看得更加清晰一點(diǎn):

微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能

每個(gè)錨點(diǎn)塊都有一個(gè)固定的高度,我們?cè)谀玫綌?shù)據(jù)渲染完頁面后,可以通過
boundingClientRect方法拿到類名為floorType各個(gè)節(jié)點(diǎn)的高度,并將這些高度裝進(jìn)anchorArray數(shù)組中,那么當(dāng)我們滾動(dòng)超過某塊錨點(diǎn)高度之后,頂部篩選項(xiàng)也會(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();

以上就是關(guān)于“微信小程序怎么實(shí)現(xiàn)錨點(diǎn)定位功能”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI