vue2.0中goods选购栏滚动算法的实现代码


Posted in Javascript onMay 17, 2017

不多说,直接代码,以便以后重复利用:

<script type="text/ecmascript-6">
import BScroll from 'better-scroll';
const ERR_OK = 0;
export default {
 props: {
  sell: {
   type: Object
  }
 },
 data() {
  return {
   goods: [],
   listHeight: [],
   scrollY: 0
  };
 },
 computed: {
  currentIndex() {
   for (let i = 0; i < this.listHeight.length; i++) {
    let height1 = this.listHeight[i];
    let height2 = this.listHeight[i + 1];
    if (!height2 || (this.scrollY >= height1 && this.scrollY < height2)) {
     return i;
    };
   }
   return 0;
  }
 },
 created() {
  this.classMap = ['decrease', 'discount', 'special', 'invoice', 'guarantee'];
  this.$http.get('/api/goods').then((response) => {
   response = response.body;
   if (response.errno === ERR_OK) {
    this.goods = response.data;
    this.$nextTick(() => {
     this._initScroll();
     this._calculateHeight();
    });
   }
  });
 },
 methods: {
  _initScroll() {
   this.menuScroll = new BScroll(this.$refs.menuwrapper, {
    click: true
   });
   this.foodScroll = new BScroll(this.$refs.foodswrapper, {
    probeType: 3
   });
   this.foodScroll.on('scroll', (pos) => {
    this.scrollY = Math.abs(Math.round(pos.y));
   });
  },
  _calculateHeight() {
   let foodList = this.$refs.foodswrapper.getElementsByClassName('food-list-hook');
   let height = 0;
   this.listHeight.push(height);
   for (let i = 0; i < foodList.length; i++) {
    let item = foodList[i];
    height += item.clientHeight;
    this.listHeight.push(height);
   }
  },
  selectMenu(index, event) {
   if (!event._constructed) {
    return;
   };
   console.log(index);
   let foodList = this.$refs.foodswrapper.getElementsByClassName('food-list-hook');
   let el = foodList[index];
   this.foodScroll.scrollToElement(el, 300);
  }
 }
};
</script>

以上所述是小编给大家介绍的vue2.0中goods选购栏滚动算法的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
EASYUI TREEGRID异步加载数据实现方法
Aug 22 Javascript
控制页面按钮在后台执行期间不重复提交的JS方法
Jun 24 Javascript
Javascript实现快速排序(Quicksort)的算法详解
Sep 06 Javascript
使用JavaScript脚本无法直接改变Asp.net中Checkbox控件的Enable属性的解决方法
Sep 16 Javascript
js判断空对象的实例(超简单)
Jul 26 Javascript
JS实现鼠标滑过显示边框的菜单效果
Sep 21 Javascript
js仿拉勾网首页穿墙广告效果
Mar 08 Javascript
JavaScript获取tr td 的三种方式全面总结(推荐)
Aug 15 Javascript
vue中各种通信传值方式总结
Feb 14 Javascript
JavaScript+HTML5 canvas实现放大镜效果完整示例
May 15 Javascript
微信小程序scroll-view点击项自动居中效果的实现
Mar 25 Javascript
Javascript Symbol原理及使用方法解析
Oct 22 Javascript
AngularJS自定义指令实现面包屑功能完整实例
May 17 #Javascript
jQuery Validate 无法验证 chosen-select元素的解决方法
May 17 #jQuery
AngularJS使用拦截器实现的loading功能完整实例
May 17 #Javascript
微信小程序城市定位的实现实例(获取当前所在国家城市信息)
May 17 #Javascript
微信小程序如何获知用户运行小程序的场景教程
May 17 #Javascript
bootstrap轮播图示例代码分享
May 17 #Javascript
bootstrap警告框示例代码分享
May 17 #Javascript
You might like
php 需要掌握的东西 不做浮躁的人
2009/12/28 PHP
PHP中addcslashes与stripcslashes函数用法分析
2016/01/07 PHP
ThinkPHP实现图片上传操作的方法详解
2017/05/08 PHP
javascript web页面刷新的方法收集
2009/07/02 Javascript
兼容多浏览器的iframe自适应高度(ie8 、谷歌浏览器4.0和 firefox3.5.3)
2009/11/04 Javascript
CSS和Javascript简单复习资料
2010/06/29 Javascript
浅析AngularJs HTTP响应拦截器
2015/12/28 Javascript
深入浅出ES6新特性之函数默认参数和箭头函数
2016/08/01 Javascript
PhotoSwipe异步动态加载图片方法
2016/08/25 Javascript
微信小程序wx:for和wx:for-item的用法详解
2018/04/01 Javascript
Vue组件中prop属性使用说明实例代码详解
2018/05/31 Javascript
浅谈super-vuex使用体验
2018/06/25 Javascript
Vue.js实现可排序的表格组件功能示例
2019/02/19 Javascript
JavaScript 空间坐标的使用
2020/08/19 Javascript
vue keep-alive的简单总结
2021/01/25 Vue.js
python为tornado添加recaptcha验证码功能
2014/02/26 Python
通过mod_python配置运行在Apache上的Django框架
2015/07/22 Python
python3使用scrapy生成csv文件代码示例
2017/12/28 Python
基于MATLAB和Python实现MFCC特征参数提取
2019/08/13 Python
python 字段拆分详解
2019/12/17 Python
SpringBoot实现登录注册常见问题解决方案
2020/03/04 Python
如何基于python3和Vue实现AES数据加密
2020/03/27 Python
Java爬虫技术框架之Heritrix框架详解
2020/07/22 Python
详解numpy.ndarray.reshape()函数的参数问题
2020/10/13 Python
Mankind西班牙男士护肤品网站:购买皮肤护理、护发和剃须
2017/04/27 全球购物
波兰灯具、照明和LED购物网站:Lampy.pl
2019/03/11 全球购物
乌克兰珠宝大卖场:Zlato.ua
2020/09/27 全球购物
2014年单位工作总结范文
2014/11/27 职场文书
给老婆的检讨书
2015/01/27 职场文书
2015年精神文明建设工作总结
2015/04/21 职场文书
安全生产培训心得体会
2016/01/18 职场文书
高二化学教学反思
2016/02/22 职场文书
用几道面试题来看JavaScript执行机制
2021/04/30 Javascript
Python绘制散乱的点构成的图的方法
2022/04/21 Python
SQL Server 中的事务介绍
2022/05/20 SQL Server
JS前端使用canvas实现扩展物体类和事件派发
2022/08/05 Javascript