微信小程序?qū)崿F(xiàn)錨點(diǎn)定位功能的方法實例
前言
在小程序開發(fā)中,我們經(jīng)常會遇到滾動列表查看的需求,那么使用錨點(diǎn)定位來實現(xiàn)可以達(dá)到交互體驗更加友好的效果,我們看下項目中實現(xiàn)的效果:
功能實現(xiàn)
采用小程序視圖容器組件實現(xiàn):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是根據(jù)不同機(jī)型的高度動態(tài)計算出來的,scroll-view有個重要屬性:scroll-into-view,它接收一個string值,即為滾動的地點(diǎn)(錨點(diǎn)),那么我們需要在scroll-view子節(jié)點(diǎn)也設(shè)置相應(yīng)的錨點(diǎn)列表:如上圖的class=floorType節(jié)點(diǎn)中的id屬性。這樣我們的滾動就有了一一對應(yīng)的關(guān)系了,在篩選塊點(diǎn)擊樓層,將toView變量設(shè)置成對應(yīng)的數(shù)據(jù),列表也會滾動到對應(yīng)的位置。
當(dāng)我們滾動列表的時候,頂部的高亮篩選項也需要對應(yīng)切換,那這個時候怎么辦呢?
我們可以在bindscroll此事件上做文章:滾動列表的時候會觸發(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):

每個錨點(diǎn)塊都有一個固定的高度,我們在拿到數(shù)據(jù)渲染完頁面后,可以通過
boundingClientRect方法拿到類名為floorType各個節(jié)點(diǎn)的高度,并將這些高度裝進(jìn)anchorArray數(shù)組中,那么當(dāng)我們滾動超過某塊錨點(diǎn)高度之后,頂部篩選項也會隨之切換到下一個。
關(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)定位滾動已完成,希望能對大家有所幫助,如有問題,歡迎溝通指出!
總結(jié)
到此這篇關(guān)于微信小程序?qū)崿F(xiàn)錨點(diǎn)定位功能的文章就介紹到這了,更多相關(guān)微信小程序錨點(diǎn)定位內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)跳轉(zhuǎn)
- 微信小程序scroll-view實現(xiàn)滾動到錨點(diǎn)左側(cè)導(dǎo)航欄點(diǎn)餐功能(點(diǎn)擊種類,滾動到錨點(diǎn))
- 微信小程序 scroll-view 實現(xiàn)錨點(diǎn)跳轉(zhuǎn)功能
- 微信小程序scroll-view錨點(diǎn)鏈接滾動跳轉(zhuǎn)功能
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)功能
- 小程序?qū)崿F(xiàn)錨點(diǎn)滑動效果
- 微信小程序 scroll-view實現(xiàn)錨點(diǎn)滑動的示例
- 微信小程序?qū)崿F(xiàn)錨點(diǎn)定位樓層跳躍的實例
- 微信小程序商城分類滾動列表錨點(diǎn)的項目實踐
相關(guān)文章
Javascript繼承機(jī)制的設(shè)計思想分享
我花了很多時間,學(xué)習(xí)這個部分,還做了很多筆記。但是都屬于強(qiáng)行記憶,無法從根本上理解。2011-08-08
JavaScript時間日期操作實例小結(jié)【5個示例】
這篇文章主要介紹了JavaScript時間日期操作,結(jié)合5個具體實例形式分析了javascript針對日期時間的各種常見操作技巧,需要的朋友可以參考下2018-12-12
Javascript絕句欣賞 一些經(jīng)典的js代碼
Javascript絕句欣賞 一些經(jīng)典的js代碼整理,學(xué)習(xí)js的朋友可以參考下2012-02-02

