溫馨提示×

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

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

微信小程序怎么實(shí)現(xiàn)外賣菜單點(diǎn)單功能

發(fā)布時(shí)間:2022-04-20 14:02:38 來(lái)源:億速云 閱讀:190 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容介紹了“微信小程序怎么實(shí)現(xiàn)外賣菜單點(diǎn)單功能”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

微信小程序怎么實(shí)現(xiàn)外賣菜單點(diǎn)單功能

1.功能僅是菜單功能一部分,僅供參考

2.需求描述:右側(cè)菜品部分在滾動(dòng)的時(shí)候,左側(cè)菜品選中分類與右側(cè)第一行菜品所在分類對(duì)應(yīng)。

我的實(shí)現(xiàn)方式:(每個(gè)菜品高度*該分類菜品數(shù)量)+菜品分類高度 = x, 每次滾動(dòng)的時(shí)候判斷當(dāng)前scrollTop是否在x范圍內(nèi)?左側(cè)選中該分類:左側(cè)不做改變;
問(wèn)題:我設(shè)置菜品高度的單位是rpx,而scrollTop的單位是px,這也就是說(shuō),上面我計(jì)算的x是個(gè)變量, 所以當(dāng)改變測(cè)試機(jī)型,這個(gè)功能就失效了。。。請(qǐng)教各位有什么好的方法沒(méi)?

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è)滾動(dòng)事件
onGoodsScroll: function (e) {
 let that = this;
 // 當(dāng)前滾動(dòng)部分距離頁(yè)面頂部距離
 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)于上面提到的問(wèn)題2,解決方法如下,但是具體參數(shù)沒(méi)搞明白怎么回事,而且定位也不是很準(zhǔn),請(qǐng)求各位有什么好方法。

// 右側(cè)滾動(dòng)事件
 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,
 })
 },

“微信小程序怎么實(shí)現(xiàn)外賣菜單點(diǎn)單功能”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(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