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 相关文章推荐
HTML页面弹出居中可拖拽的自定义窗口层
May 07 Javascript
javascript实现百度地图鼠标滑动事件显示、隐藏
Apr 02 Javascript
javascript实现textarea中tab键的缩排处理方法
Jun 26 Javascript
Bootstrap每天必学之导航组件
Apr 25 Javascript
javaScript实现滚动条事件详解
Mar 24 Javascript
input type=file 选择图片并且实现预览效果的实例
Oct 26 Javascript
解决vue中虚拟dom,无法实时更新的问题
Sep 15 Javascript
js+html5 canvas实现ps钢笔抠图
Apr 28 Javascript
学习 Vue.js 遇到的那些坑
Feb 02 Vue.js
vue实现拖拽进度条
Mar 01 Vue.js
JavaScript实现简单计时器
Jun 22 Javascript
vue数据字典取键值项目的字典问题
Apr 12 Vue.js
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调用mysql数据 dbclass类
2011/05/07 PHP
PHP利用hash冲突漏洞进行DDoS攻击的方法分析
2015/03/26 PHP
Laravel中log无法写入问题的解决
2017/06/17 PHP
thinkPHP+mysql+ajax实现的仿百度一下即时搜索效果详解
2019/07/15 PHP
推荐30个新鲜出炉的精美 jQuery 效果
2012/03/26 Javascript
js实现具有高亮显示效果的多级菜单代码
2015/09/01 Javascript
JavaScript简单计算人的年龄示例
2017/04/15 Javascript
Angular2监听页面大小变化的解决方法
2017/10/09 Javascript
浅谈es6语法 (Proxy和Reflect的对比)
2017/10/24 Javascript
js操作二进制数据方法
2018/03/03 Javascript
vue2.0 如何在hash模式下实现微信分享
2019/01/22 Javascript
ES6 Object.assign()的用法及其使用
2020/01/18 Javascript
[03:56]还原FTP电影首映式 DOTA2群星拼出遗迹世界
2014/03/26 DOTA
[40:03]RNG vs VG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python中的自定义函数学习笔记
2014/09/23 Python
Windows系统下安装Python的SSH模块教程
2015/02/05 Python
Python处理JSON时的值报错及编码报错的两则解决实录
2016/06/26 Python
Python引用类型和值类型的区别与使用解析
2017/10/17 Python
python爬虫爬取快手视频多线程下载功能
2018/02/28 Python
python线程中同步锁详解
2018/04/27 Python
深入分析python中整型不会溢出问题
2018/06/18 Python
python计算两个矩形框重合百分比的实例
2018/11/07 Python
Pandas DataFrame 取一行数据会得到Series的方法
2018/11/10 Python
不到40行代码用Python实现一个简单的推荐系统
2019/05/10 Python
python实现一次性封装多条sql语句(begin end)
2020/06/06 Python
python的help函数如何使用
2020/06/11 Python
Python Serial串口基本操作(收发数据)
2020/11/06 Python
美国翻新电子产品商店:The Store
2019/10/08 全球购物
沙特阿拉伯家用电器和电子产品购物网站:Sheta and Saif
2020/04/03 全球购物
市场营销毕业生自荐信
2013/11/23 职场文书
应用英语专业自荐信
2014/01/26 职场文书
军训自我鉴定范文
2014/02/13 职场文书
主管竞聘书范文
2014/03/31 职场文书
园林专业毕业生自荐信
2014/07/04 职场文书
2015年社区矫正工作总结
2015/04/21 职场文书
简单了解 MySQL 中相关的锁
2021/05/25 MySQL