微信小程序左右菜单mysql_微信小程序做出外卖菜单点单功能

本文介绍了如何在微信小程序中实现外卖菜单点单功能,特别是在右侧菜品滚动时,确保左侧菜品分类与右侧对应。文章指出在不同设备上由于单位不一致导致功能失效的问题,并提供了初步解决方案,但存在定位不准的困扰。作者期待找到更优的处理方法。
摘要由CSDN通过智能技术生成

这次给大家带来微信小程序做出外卖菜单点单功能,的注意事项有哪些,下面就是实战案例,一起来看一下。

1d84ddd3c5010912ba860545549733b8.gif

1.功能仅是菜单功能一部分,仅供参考

2.需求描述:右侧菜品部分在滚动的时候,左侧菜品选中分类与右侧第一行菜品所在分类对应。

我的实现方式:(每个菜品高度*该分类菜品数量)+菜品分类高度 = x, 每次滚动的时候判断当前scrollTop是否在x范围内?左侧选中该分类:左侧不做改变;

问题:我设置菜品高度的单位是rpx,而scrollTop的单位是px,这也就是说,上面我计算的x是个变量, 所以当改变测试机型,这个功能就失效了。。。请教各位有什么好的方法没?onLoad(e) {

let goodsList = this.data.goodsList;

// 初始化每项菜品距离顶部的距离

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;

},

// 右侧滚动事件

onGoodsScroll: function (e) {

let that = this;

// 当前滚动部分距离页面顶部距离

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

})

}

}

}

关于上面提到的问题2,解决方法如下,但是具体参数没搞明白怎么回事,而且定位也不是很准,请求各位有什么好方法。// 右侧滚动事件

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,

})

},

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值