vue2.0 better-scroll 实现移动端滑动的示例代码


Posted in Javascript onJanuary 25, 2018

写在前面的话:

上一篇文章实现了滑动效果,这部分来试试左右联动效果的实现方法吧

效果:滑动右侧时,左侧也能有相应的变化;点击左侧时,右侧也能自动定位到相应的位置。

如下图所示界面,左侧为分栏,右侧为分栏详情。

vue2.0 better-scroll 实现移动端滑动的示例代码

滑动右边使左边联动的大概的思路:

1)要知道右侧的列表中,每一个分栏所占的高度,存进一个数组中。

2)实现左边联动,则必须要监控 “scroll”事件,获取其高度

3)将scroll 的高度与右侧分栏的高度进行比较,获得其 index 值

4)左侧的分类中,使与 index 相应的分栏高亮即可~

余留的问题:额,左侧怎么跟着一起滚动?应该还需要判断一下当前左侧栏中的scroll的位置,然后使之跟随变化,但是不同尺寸的手机,高度不一,怎么解决???我不知道……

点击左边时,右边实现自动定位的大概思路:

1)首先要使点击有效,因为 better-scroll将默认事件都阻止了

2)为左侧的分栏绑定点击事件,并获取 index ,然后使右边的相应 index 分类滚动就行了~so easy ....but!!!

怎么下手?!!

1. 先实现滑动右边触发左边的功能:

做法:

(1)定义变量先~ 在data中加入一个 listHight: [] 数组;一个变量scrollY : 0,用来装目前的scroll的y位置坐标

(2)在methods 中定义一个函数计算高度,此处还要用到一个知识点(如何获取 分类列表dom元素?)还记得上一篇中使用到的this.$refs 吗?

我们先给要获取高度的那个元素取个类名,名字叫:“food-list-hook”:

let foodList =this.$refs.foodsWrapper.getElementsByClassName('food-list-hook') 这样就获取了所有分类列表啦,计算方法定义如下:

_calculateHeight () {
    // console.log(this)
    let foodList = this.$refs.foodsWrapper.getElementsByClassName('food-list-hook')
    let height = 0
    this.listHight.push(height)
    for (let i = 0; i < foodList.length; i++) {
     let item = foodList[i]
     height += item.clientHeight
     this.listHight.push(height)
    }
}

(3)然后在计算属性computed 中,来比较数组中的高度值与当前的 scroll 的y坐标值,返回的是当前所在高度的index值:

在执行这一步时,scrollY的值,要怎么得到?(通过better-scroll 检测“scroll”事件得到,此时,需要给其加上相应的参数,做法如截图中画红线处所示)

vue2.0 better-scroll 实现移动端滑动的示例代码

currentIndex () {
    for (let i = 0; i < this.listHight.length; i++) {
     let height1 = this.listHight[i]
     let height2 = this.listHight[i + 1]
     if (!height2 || (this.scrollY >= height1 && this.scrollY < height2)) {
      return i
     }
    }
    return 0
   }
 }

(4)在 template 中,将此index 值绑定到index 值相等的左侧的列表分栏中,并指定一个类名,叫 current,如下图中的 画红线的部分:

vue2.0 better-scroll 实现移动端滑动的示例代码 

(5)在style中,将相应的current 类加上相应的样式即可:

vue2.0 better-scroll 实现移动端滑动的示例代码

2. 再来实现点击左边,右边联动的效果

(1)使 左边栏 点击有效,如下图红线标注所示:

vue2.0 better-scroll 实现移动端滑动的示例代码

(2)为左侧栏 添加相应的点击事件:

vue2.0 better-scroll 实现移动端滑动的示例代码

(3)在methods 中编写点击触发的事件 selectMenu()方法,利用 获取的 $index 使右边进行相应的滚动,其中 300ms是加上了一个过渡效果:

vue2.0 better-scroll 实现移动端滑动的示例代码

试试吧~

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

Javascript 相关文章推荐
JavaScript 解析读取XML文档 实例代码
Jul 07 Javascript
JavaScript可否多线程? 深入理解JavaScript定时机制
May 23 Javascript
jquery阻止冒泡事件使用模拟事件
Sep 06 Javascript
div模拟选择框示例代码
Nov 03 Javascript
JavaScript极简入门教程(一):基础篇
Oct 25 Javascript
AngularJS中比较两个数组是否相同
Aug 24 Javascript
微信小程序入门教程
Nov 18 Javascript
BootStrap Validator 版本差异问题导致的submitHandler失效问题的解决方法
Dec 01 Javascript
vue.js实现备忘录功能的方法
Jul 10 Javascript
JQuery 选择器、DOM节点操作练习实例
Sep 28 jQuery
使用vue-aplayer插件时出现的问题的解决
Mar 02 Javascript
深入理解 Koa 框架中间件原理
Oct 18 Javascript
mui框架 页面无法滚动的解决方法(推荐)
Jan 25 #Javascript
vue使用 better-scroll的参数和方法详解
Jan 25 #Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 #Javascript
基于vue开发的在线付费课程应用过程
Jan 25 #Javascript
基于vue 开发中出现警告问题去除方法
Jan 25 #Javascript
关于express与koa的使用对比详解
Jan 25 #Javascript
在vue项目创建的后初始化首次使用stylus安装方法分享
Jan 25 #Javascript
You might like
PHP静态类
2006/11/25 PHP
php基础知识:类与对象(2) 自动加载对象
2006/12/13 PHP
php通过ksort()函数给关联数组按照键排序的方法
2015/03/18 PHP
Symfony2开发之控制器用法实例分析
2016/02/05 PHP
Mozilla 表达式 __noSuchMethod__
2009/04/05 Javascript
ext 列表页面关于多行查询的办法
2010/03/25 Javascript
javascript XMLHttpRequest对象全面剖析
2010/04/24 Javascript
JS 实现完美include载入实现代码
2010/08/05 Javascript
JavaScript面向对象程序设计三 原型模式(上)
2011/12/21 Javascript
JS保留两位小数,多位小数的示例代码
2014/01/07 Javascript
JS 对象属性相关(检查属性、枚举属性等)
2015/04/05 Javascript
JavaScript必知必会(五) eval 的使用
2016/06/08 Javascript
你不知道的 javascript【推荐】
2017/01/08 Javascript
JavaScript实现的select点菜功能示例
2017/01/16 Javascript
AngularJS实现页面跳转后自动弹出对话框实例代码
2017/08/02 Javascript
JS继承与闭包及JS实现继承的三种方式
2017/10/15 Javascript
使用bootstrap实现下拉框搜索功能的实例讲解
2018/08/10 Javascript
JS如何获取地址栏的参数实例讲解
2018/10/06 Javascript
Postman的下载及安装教程详解
2018/10/16 Javascript
VUE 实现动态给对象增加属性,并触发视图更新操作示例
2019/11/29 Javascript
JS实现audio音频剪裁剪切复制播放与上传(步骤详解)
2020/07/28 Javascript
Vue性能优化的方法
2020/07/30 Javascript
vue中实现弹出层动画效果的示例代码
2020/09/25 Javascript
解决Vue watch里调用方法的坑
2020/11/07 Javascript
python numpy 部分排序 寻找最大的前几个数的方法
2018/06/27 Python
浅谈dataframe中更改列属性的方法
2018/07/10 Python
python修改txt文件中的某一项方法
2018/12/29 Python
python 对xml解析的示例
2021/02/27 Python
美国最好的钓鱼、狩猎和划船装备商店:Bass Pro Shops
2018/12/02 全球购物
仓库班组长岗位职责
2013/12/12 职场文书
消防应急演练方案
2014/02/12 职场文书
2014年药剂科工作总结
2014/11/26 职场文书
报名委托书
2015/01/29 职场文书
找规律教学反思
2016/02/23 职场文书
用Python将库打包发布到pypi
2021/04/13 Python
php7中停止php-fpm服务的方法详解
2021/05/09 PHP