微信小程序实现美团菜单


Posted in Javascript onJune 06, 2018

本文实例为大家分享了微信小程序实现美团菜单的具体代码,供大家参考,具体内容如下

微信小程序实现美团菜单

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,
 })
 },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery()方法的第二个参数详解
Apr 29 Javascript
jQuery+PHP实现可编辑表格字段内容并实时保存
Oct 09 Javascript
JS显示日历和天气的方法
Mar 01 Javascript
js数组的五种迭代方法及两种归并方法(推荐)
Jun 14 Javascript
详解Vue 动态添加模板的几种方法
Apr 25 Javascript
React Native使用百度Echarts显示图表的示例代码
Nov 07 Javascript
jQuery实现所有验证通过方可提交的表单验证
Nov 21 jQuery
element-ui 表格实现单元格可编辑的示例
Feb 26 Javascript
原生JS实现的雪花飘落动画效果
May 03 Javascript
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
Jun 17 Javascript
Javascript地址引用代码实例解析
Feb 25 Javascript
vue 判断元素内容是否超过宽度的方式
Jul 29 Javascript
详解express + mock让前后台并行开发
Jun 06 #Javascript
vue element项目引入icon图标的方法
Jun 06 #Javascript
vue脚手架搭建过程图解
Jun 06 #Javascript
vue左右侧联动滚动的实现代码
Jun 06 #Javascript
Express本地测试HTTPS的示例代码
Jun 06 #Javascript
微信小程序仿美团城市选择
Jun 06 #Javascript
jQuery实现百度图片移入移出内容提示框上下左右移动的效果
Jun 05 #jQuery
You might like
PHP的范围解析操作符(::)的含义分析说明
2011/07/03 PHP
PHP迭代器实现斐波纳契数列的函数
2013/11/12 PHP
在JavaScript中通过URL传递汉字的方法
2007/04/09 Javascript
ext实现完整的登录代码
2008/08/08 Javascript
javascript下判断一个元素是否存在的代码
2010/03/05 Javascript
js变换显示图片的实例
2013/04/16 Javascript
js里取容器大小、定位、距离等属性搜集整理
2013/08/19 Javascript
javascript实现数字+字母验证码的简单实例
2014/02/10 Javascript
原生javascript实现获取指定元素下所有后代元素的方法
2014/10/28 Javascript
纯JavaScript实现的分页插件实例
2015/07/14 Javascript
JS基于FileSystemObject创建一个指定路径的TXT文本文件
2015/08/05 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
JavaScript驾驭网页-CSS与DOM
2016/03/24 Javascript
Google 地图API Map()构造器详解
2016/08/06 Javascript
Validform表单验证总结篇
2016/10/31 Javascript
Java中int与integer的区别(基本数据类型与引用数据类型)
2017/02/19 Javascript
Javascript Promise用法详解
2018/05/10 Javascript
一步一步的了解webpack4的splitChunk插件(小结)
2018/09/17 Javascript
用vue-cli开发vue时的代理设置方法
2018/09/20 Javascript
CKEditor 4.4.1 添加代码高亮显示插件功能教程【使用官方推荐Code Snippet插件】
2019/06/14 Javascript
解决layui中onchange失效以及form动态渲染失效的问题
2019/09/27 Javascript
[04:03]辉夜杯主赛事 12月25日RECAP精彩回顾
2015/12/26 DOTA
[39:11]DOTA2上海特级锦标赛C组资格赛#2 LGD VS Newbee第二局
2016/02/28 DOTA
浅谈python写入大量文件的问题
2018/11/09 Python
python制作mysql数据迁移脚本
2019/01/01 Python
django+tornado实现实时查看远程日志的方法
2019/08/12 Python
Python绘图实现台风路径可视化代码实例
2020/10/23 Python
美国值得信赖的婚恋交友网站:eHarmony
2018/10/04 全球购物
保洁主管岗位职责
2013/11/20 职场文书
企划专员岗位职责
2013/12/09 职场文书
2014年污水处理厂工作总结
2014/12/19 职场文书
考试作弊检讨
2015/01/27 职场文书
志愿者服务活动总结报告
2015/05/06 职场文书
JavaScript嵌入百度地图API的最详细方法
2021/04/16 Javascript
代码解析React中setState同步和异步问题
2021/06/03 Javascript
delete in子查询不走索引问题分析
2022/07/07 MySQL