微信小程序?qū)崿F(xiàn)美團(tuán)菜單
本文實(shí)例為大家分享了微信小程序?qū)崿F(xiàn)美團(tuán)菜單的具體代碼,供大家參考,具體內(nèi)容如下

1.功能僅是菜單功能一部分,僅供參考
2.需求描述:右側(cè)菜品部分在滾動的時候,左側(cè)菜品選中分類與右側(cè)第一行菜品所在分類對應(yīng)。
我的實(shí)現(xiàn)方式:(每個菜品高度*該分類菜品數(shù)量)+菜品分類高度 = x, 每次滾動的時候判斷當(dāng)前scrollTop是否在x范圍內(nèi)?左側(cè)選中該分類:左側(cè)不做改變;
問題:我設(shè)置菜品高度的單位是rpx,而scrollTop的單位是px,這也就是說,上面我計(jì)算的x是個變量, 所以當(dāng)改變測試機(jī)型,這個功能就失效了。。。請教各位有什么好的方法沒?
onLoad(e) {
let goodsList = this.data.goodsList;
// 初始化每項(xiàng)菜品距離頂部的距離
for (let i = 0; i < goodsList.length; i++) {
if (i != 0)
goodsList[i].scrollTop = parseInt(goodsList[i - 1].scrollTop) + parseInt((goodsList[i - 1].goods.length * 90) + 35)
}
this.data.goodsList = goodsList;
},
// 右側(cè)滾動事件
onGoodsScroll: function (e) {
let that = this;
// 當(dāng)前滾動部分距離頁面頂部距離
let scrollTop = parseInt(e.detail.scrollTop);
let goodsList = that.data.goodsList;
for (let i = 0; i < goodsList.length; i++) {
let currentScrollTop = goodsList[i].scrollTop;
let nextScrollTop = 0;
if ((i + 1) == goodsList.length)
nextScrollTop = goodsList[i].scrollTop;
else
nextScrollTop = goodsList[i + 1].scrollTop;
if (currentScrollTop < scrollTop && scrollTop < nextScrollTop) {
that.setData({
classifyIdLeft: goodsList[i].id,
classifySeleted: goodsList[i].id
})
}
}
}
關(guān)于上面提到的問題2,解決方法如下,但是具體參數(shù)沒搞明白怎么回事,而且定位也不是很準(zhǔn),請求各位有什么好方法。
// 右側(cè)滾動事件
onGoodsScroll: function (e) {
let that = this;
let scale = e.detail.scrollWidth / 600;
let scrollTop = e.detail.scrollTop / scale;
let h = 0;
let classifySeleted;
let len = that.data.goodsList.length;
that.data.goodsList.forEach(function (classify, i) {
var _h = 70 + classify.goods.length * 180;
if (scrollTop >= h - 100 / scale) {
classifySeleted = classify.id;
}
h += _h;
});
that.setData({
classifySeleted: classifySeleted,
classifyIdLeft: classifySeleted,
})
},
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
提供復(fù)制本站內(nèi)容時出現(xiàn),該文章轉(zhuǎn)自腳本之家等字樣的js代碼
提供復(fù)制本站內(nèi)容時出現(xiàn),該文章轉(zhuǎn)自腳本之家等字樣的js代碼...2007-03-03
基于JavaScript實(shí)現(xiàn)動態(tài)創(chuàng)建表格和增加表格行數(shù)
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)動態(tài)創(chuàng)建表格和增加表格行數(shù)的相關(guān)資料,需要的朋友可以參考下2015-12-12
JS數(shù)組合并push與concat區(qū)別分析
這篇文章主要介紹了JS數(shù)組合并push與concat區(qū)別,結(jié)合實(shí)例形式分析了JavaScript中針對數(shù)組合并操作使用push與concat的區(qū)別,需要的朋友可以參考下2015-12-12
javascript強(qiáng)制彈出新窗口實(shí)現(xiàn)代碼
javascript強(qiáng)制彈出新窗口,主要是利用的動態(tài)創(chuàng)建鏈接。2009-12-12
JavaScript兩種axios取消請求方式小結(jié)
本文主要介紹了JavaScript兩種axios取消請求方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
JavaScript驗(yàn)證18位身份證號碼最后一位正確性的實(shí)現(xiàn)代碼
這篇文章主要介紹了JavaScript驗(yàn)證18位身份證號碼最后一位正確性的實(shí)現(xiàn)代碼,小編親測有效,需要的朋友可以參考下2014-08-08

