小程序实现美团菜单的示例

  介绍

小编给大家分享一下小程序实现美团菜单的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获、下面让我们一起去了解一下吧!

具体内容如下

小程序实现美团菜单的示例

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

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

我的实现方式:(每个菜品高度*该分类菜品数量)+菜品分类高度=x,每次滚动的时候判断当前scrollTop是否在x范围内?左侧选中该分类:左侧不做改变;
问题:我设置菜品高度的单位是rpx,而scrollTop的单位是px,这也就是说,上面我计算的x是个变量,所以当改变测试机型,这个功能就失效了…请教各位有什么好的方法没?

onLoad (e), {   ,let  goodsList =, this.data.goodsList;   ,//初始化每项菜品距离顶部的距离   ,for  (let 小姐:=,0;,小姐:& lt;, goodsList.length;,我+ +),{   ,if (小姐;!=,0)   ,goodsList[我].scrollTop =,方法(goodsList[小姐,安康;1].scrollTop), +,方法((goodsList[小姐,安康;1].goods.length  *, 90), +, 35)   ,}=,,this.data.goodsList  goodsList;   },//,右侧滚动事件   onGoodsScroll: function  (e), {=,let  that ;   ,//当前滚动部分距离页面顶部距离   ,let  scrollTop =,方法(e.detail.scrollTop);   ,let  goodsList =, that.data.goodsList;   ,for  (let 小姐:=,0;,小姐:& lt;, goodsList.length;,我+ +),{   ,let  currentScrollTop =, goodsList[我].scrollTop;   ,let  nextScrollTop =, 0;   ,if ((小姐:+,- 1),==,goodsList.length)=,,nextScrollTop  goodsList[我].scrollTop;   其他的,=,,nextScrollTop  goodsList[小姐:+,- 1].scrollTop;      ,if  (currentScrollTop  & lt;, scrollTop ,,, scrollTop  & lt;, nextScrollTop), {   ,that.setData ({   ,classifyIdLeft: goodsList[我].id,   ,classifySeleted: goodsList[我].id   ,})   ,}   ,}   }

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

//,右侧滚动事件   ,onGoodsScroll: function  (e), {=,let  that ;   ,let  scale =, e.detail.scrollWidth /, 600;   ,let  scrollTop =, e.detail.scrollTop /,规模;   ,let  h =, 0;   ,let  classifySeleted;   ,let  len =, that.data.goodsList.length;      ,that.data.goodsList.forEach (function (分类,,我),{   70年,var  _h =,, +, classify.goods.length  *, 180;   ,if  (scrollTop 祝辞=,h 作用;100年,/,规模),{=,,classifySeleted  classify.id;   ,}   +=,h  _h;   ,});   ,that.setData ({   ,classifySeleted: classifySeleted,   ,classifyIdLeft: classifySeleted,   ,})   },

以上是“小程序实现美团菜单的示例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

小程序实现美团菜单的示例