微信小程序?qū)崿F(xiàn)錨點(diǎn)定位功能的方法實(shí)例
前言
在小程序開(kāi)發(fā)中,我們經(jīng)常會(huì)遇到滾動(dòng)列表查看的需求,那么使用錨點(diǎn)定位來(lái)實(shí)現(xiàn)可以達(dá)到交互體驗(yàn)更加友好的效果,我們看下項(xiàng)目中實(shí)現(xià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ì)算出來(lái)的,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)塊所占頁(yè)面高度的數(shù)組總和,用圖可以看得更加清晰一點(diǎn):
每個(gè)錨點(diǎn)塊都有一個(gè)固定的高度,我們?cè)谀玫綌?shù)據(jù)渲染完頁(yè)面后,可以通過(guò)
boundingClientRect方法拿到類名為floorType各個(gè)節(jié)點(diǎn)的高度,并將這些高度裝進(jìn)anchorArray數(shù)組中,那么當(dāng)我們滾動(dòng)超過(guò)某塊錨點(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();
到這里,我們的錨點(diǎn)定位滾動(dòng)已完成,希望能對(duì)大家有所幫助,如有問(wèn)題,歡迎溝通指出!
總結(jié)
到此這篇關(guān)于微信小程序?qū)崿F(xiàn)錨點(diǎn)定位功能的文章就介紹到這了,更多相關(guān)微信小程序錨點(diǎn)定位內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)跳轉(zhuǎn)
- 微信小程序scroll-view實(shí)現(xiàn)滾動(dòng)到錨點(diǎn)左側(cè)導(dǎo)航欄點(diǎn)餐功能(點(diǎn)擊種類,滾動(dòng)到錨點(diǎn))
- 微信小程序 scroll-view 實(shí)現(xiàn)錨點(diǎn)跳轉(zhuǎn)功能
- 微信小程序scroll-view錨點(diǎn)鏈接滾動(dòng)跳轉(zhuǎn)功能
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)功能
- 小程序?qū)崿F(xiàn)錨點(diǎn)滑動(dòng)效果
- 微信小程序 scroll-view實(shí)現(xiàn)錨點(diǎn)滑動(dòng)的示例
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)定位樓層跳躍的實(shí)例
- 微信小程序商城分類滾動(dòng)列表錨點(diǎn)的項(xiàng)目實(shí)踐
相關(guān)文章
基于el-slider實(shí)現(xiàn)一個(gè)能拖動(dòng)的時(shí)間范圍選擇器
這篇文章主要介紹了基于el-slider實(shí)現(xiàn)一個(gè)能拖動(dòng)的時(shí)間范圍選擇器,并通過(guò)實(shí)例代碼介紹了基于element-ui el-slider實(shí)現(xiàn)滑動(dòng)限位器的方法,需要的朋友可以參考下2024-02-02Javascript中的基本類型和引用類型概述說(shuō)明
這篇文章主要介紹了Javascript中的基本類型和引用類型的相關(guān)資料,包括基本類型和引用類型的概念及區(qū)別,數(shù)據(jù)類型檢測(cè)給大家詳細(xì)介紹了js基本類型和引用類型,非常不錯(cuò),需要的朋友可以參考下2022-11-11JavaScript通過(guò)Date-Mask將日期轉(zhuǎn)換成字符串的方法
這篇文章主要介紹了JavaScript通過(guò)Date-Mask將日期轉(zhuǎn)換成字符串的方法,涉及javascript日期、數(shù)組及字符串操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06手把手教你用JS實(shí)現(xiàn)回車評(píng)論功能
最近在寫(xiě)一個(gè)問(wèn)答功能,類似于評(píng)論,下面這篇文章主要給大家介紹了關(guān)于如何用JS實(shí)現(xiàn)回車評(píng)論功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06