91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序怎么實現錨點定位功能

發布時間:2022-04-05 11:03:01 來源:億速云 閱讀:347 作者:iii 欄目:移動開發

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

實現效果:

微信小程序怎么實現錨點定位功能            

功能實現

采用小程序視圖容器組件實現:scroll-view

這里需要注意的是,豎向滾動時,scroll-view需要指定一個固定高度,我們看下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是根據不同機型的高度動態計算出來的,scroll-view有個重要屬性:scroll-into-view,它接收一個string值,即為滾動的地點(錨點),那么我們需要在scroll-view子節點也設置相應的錨點列表:如上圖的class=floorType節點中的id屬性。這樣我們的滾動就有了一一對應的關系了,在篩選塊點擊樓層,將toView變量設置成對應的數據,列表也會滾動到對應的位置。
當我們滾動列表的時候,頂部的高亮篩選項也需要對應切換,那這個時候怎么辦呢?

我們可以在bindscroll此事件上做文章:滾動列表的時候會觸發此事件。

關鍵代碼:

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各個節點的高度,并將這些高度裝進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();

以上就是關于“微信小程序怎么實現錨點定位功能”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

中阳县| 庆阳市| 南通市| 湘阴县| 固原市| 井研县| 南乐县| 尚义县| 乌什县| 闽侯县| 梓潼县| 凌海市| 巴中市| 寿阳县| 东源县| 哈巴河县| 常宁市| 永德县| 石林| 万全县| 阿克| 昔阳县| 盐山县| 玉环县| 黄山市| 新宁县| 枞阳县| 黄大仙区| 石嘴山市| 正安县| 鄄城县| 土默特右旗| 陕西省| 新密市| 嘉荫县| 太白县| 金华市| 杂多县| 星子县| 横山县| 吕梁市|