微信小程序 美团菜单

来源:互联网 发布:淘宝高利润产品 编辑:程序博客网 时间:2024/04/29 06:15

这里写图片描述
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      })    }  }}

Demo链接: http://pan.baidu.com/s/1pLhWlh5 密码: 1gk6

关于上面提到的问题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,    })  },
原创粉丝点击