微信小程序实现美团菜单
2018-06-06 10:34
706 查看
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, }) },
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 微信小程序 仿美团分类菜单 swiper分类菜单
- 微信小程序实现弹出菜单
- 微信小程序 仿美团分类菜单 swiper分类菜单
- 微信小程序 仿美团分类菜单 swiper分类菜单
- 微信小程序实现action-sheet弹出底部菜单功能【附源码下载】
- 微信小程序左滑动显示菜单功能的实现
- 005 - 微信小程序 仿美团分类菜单 swiper分类菜单
- 微信小程序菜单实现
- 微信小程序 仿美团分类菜单 swiper分类菜单
- 微信小程序下拉筛选菜单WXDropDownMenu组件实现下拉动画
- 微信小程序实现跟随菜单效果和循环嵌套加载数据
- 微信小程序实现弹出菜单功能
- 微信小程序例子——点击文字实现页面跳转
- 用callback增强链表模块来实现命令行菜单小程序V2.8
- Android开发之多级下拉列表菜单实现(仿美团,淘宝等)
- 微信小程序开发——下拉刷新的实现
- 详解微信小程序 通过控制CSS实现view隐藏与显示
- 微信小程序中做用户登录与登录态维护的实现详解
- Android实战: 如何实现 图片分享菜单加入指定程序
- 微信小程序--下拉菜单(带动画)实现