Vue 开发音乐播放器之歌手页右侧快速入口功能


Posted in Javascript onAugust 08, 2018

快速入口的列表是其实是之前处理的歌手的数据中的关于title的列表

Vue 开发音乐播放器之歌手页右侧快速入口功能

shorcutList属性是计算属性 通过ret数组中的title计算到的

所以我们要在singer.vue组件中将数据传入到list-view组件

Vue 开发音乐播放器之歌手页右侧快速入口功能

list-vue 组件在props中接受

Vue 开发音乐播放器之歌手页右侧快速入口功能

shortcut快速入口列表 所用到的属性 是计算属性 通过将singer.vue组件中传入到list-view组件中的数据计算得到

Vue 开发音乐播放器之歌手页右侧快速入口功能

将得到的shortcutList数据通过v-for展示在页面

Vue 开发音乐播放器之歌手页右侧快速入口功能

效果图如下

Vue 开发音乐播放器之歌手页右侧快速入口功能

下面来实现功能

1、点击右侧快速入口 左侧的列表跳转到对应位置

实现:给shortcutList一个touchstart方法

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

此时 就已实现点击右侧的快速入口 左侧的歌手列表跳转功能

功能2、滑动右侧的快速入口 左侧的歌手列表对应滑动 我们只需要获取到手指放在右侧快速列表之前的位置 和获取到手指离开右侧快速列表的位置 做差 然后处理快速列表的li的高度 就可以知道变化的索引的值 然后让左侧的歌手列表运动到变化的索引处即可

给shortcutList一个@touchmove.stop.prevent="onShortcutTouchMove"

Vue 开发音乐播放器之歌手页右侧快速入口功能

手指放上去的时候:

Vue 开发音乐播放器之歌手页右侧快速入口功能

手指离开的时候:

Vue 开发音乐播放器之歌手页右侧快速入口功能

功能三:当左侧歌手列表滑到对应的位置 右侧快速入口对应索引处高亮显示 此时要监听scroll事件 将左侧列表滚动的scrollY与左侧列表对应的每个区间li的高度将比较 得到currentIndex的值 当右侧快速入口的index===currentIndex时高亮显示

获取各区间高度值

Vue 开发音乐播放器之歌手页右侧快速入口功能

各区间高度对应的值

Vue 开发音乐播放器之歌手页右侧快速入口功能

因为我们之前给height=0 然后前一个的上限值 等于后一个的下限值 所以我们的高度数组中的值 会比右侧列表中的真实数据的个数多一个

Vue 开发音乐播放器之歌手页右侧快速入口功能

监控data 我们需要监控两个值:一个是当scroll滚动列表中的数据变化导致高度变化的时候 我们对应的高度区间也要变化

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

上图中的scroll属性是儿子组件scroll的 scroll方法是父亲组件listview的

儿子组件:this.scroll.on('scroll',()=>{me.$emit('scroll',pos)})

这行代码的意思是:当我触发滚动事件的时候就向上派发一个名为scroll的方法 还带有参数pos 父组件接受到派发的这个方法之后 就触发自己绑定的方法 本项目中父组件自己绑定的方法叫scroll

$emit()方法的第一个参数scroll要和父组件的@scroll项对应

Vue 开发音乐播放器之歌手页右侧快速入口功能

f父元素触发自己绑定的scroll方法之后 将pos.y的值赋值给了this.scrollY

Vue 开发音乐播放器之歌手页右侧快速入口功能

j接下来我们监控listview中的data的变化 以及scrollY的变化 每次data变了就要重新计算calculateHeight

监控到scrollY的变化然后将_calculateHeight()方法中得到的各区间的数组的高度与scrollY相比较

得到对应的currentIndex

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

Vue 开发音乐播放器之歌手页右侧快速入口功能

总结

以上所述是小编给大家介绍的Vue 开发音乐播放器之歌手页右侧快速入口功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
可缩放Reloaded-一个针对可缩放元素的复用组件
Mar 10 Javascript
jquery如何把数组变为字符串传到服务端并处理
Apr 30 Javascript
jQuery 如何先创建、再修改、后添加DOM元素
May 20 Javascript
jQuery结合HTML5制作的爱心树表白动画
Feb 01 Javascript
Google Maps基础及实例解析
Aug 06 Javascript
关于微信上网页图片点击全屏放大效果
Dec 19 Javascript
通过修改360抢票的刷新频率和突破8车次限制实现方法
Jan 04 Javascript
Vue结合原生js实现自定义组件自动生成示例
Jan 21 Javascript
react router4+redux实现路由权限控制的方法
May 03 Javascript
JS引用传递与值传递的区别与用法分析
Jun 01 Javascript
js实现图片跟随鼠标移动效果
Oct 16 Javascript
vue scroll滚动判断的实现(是否滚动到底部、滚动方向、滚动节流、获取滚动区域dom元素)
Jun 11 Javascript
jQuery中ajax请求后台返回json数据并渲染HTML的方法
Aug 08 #jQuery
Vue2.0 实现歌手列表滚动及右侧快速入口功能
Aug 08 #Javascript
JavaScript引用类型Date常见用法实例分析
Aug 08 #Javascript
js使用ajax传值给后台,后台返回字符串处理方法
Aug 08 #Javascript
JavaScript引用类型Object常见用法实例分析
Aug 08 #Javascript
微信小程序wepy框架笔记小结
Aug 08 #Javascript
angularJs中$http获取后台数据的实例讲解
Aug 08 #Javascript
You might like
深入分析使用mysql_fetch_object()以对象的形式返回查询结果
2013/06/05 PHP
php获取一定范围内取N个不重复的随机数
2016/05/28 PHP
php strftime函数获取日期时间(switch用法)
2018/05/16 PHP
再说AutoComplete自动补全之实现原理
2011/11/05 Javascript
JS 各种网页尺寸判断实例方法
2013/04/18 Javascript
javascript中创建对象的几种方法总结
2013/11/01 Javascript
node.js中的path.normalize方法使用说明
2014/12/08 Javascript
Shell脚本实现Linux系统和进程资源监控
2015/03/05 Javascript
HTML5+setCutomValidity()函数验证表单实例分享
2015/04/24 Javascript
JavaScript面向对象之私有静态变量实例分析
2016/01/14 Javascript
JS实现复制内容到剪贴板功能兼容所有浏览器(推荐)
2016/06/17 Javascript
Javascript实现图片加载从模糊到清晰显示的方法
2016/06/21 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
2016/10/27 Javascript
前端分页功能的实现以及原理(jQuery)
2017/01/22 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
基于JavaScript实现轮播图效果
2021/01/02 Javascript
JavaScript 判断浏览器是否是IE
2021/02/19 Javascript
Python实现的简单发送邮件脚本分享
2014/11/07 Python
pip安装Python库时遇到的问题及解决方法
2017/11/23 Python
python实现画圆功能
2018/01/25 Python
python实现隐马尔科夫模型HMM
2018/03/25 Python
Python----数据预处理代码实例
2019/03/20 Python
详解Python传入参数的几种方法
2019/05/16 Python
Python中函数参数匹配模型详解
2019/06/09 Python
python基于celery实现异步任务周期任务定时任务
2019/12/30 Python
巴西Bo.Bô官方在线商店:经营奢侈品时尚业务
2020/03/16 全球购物
加拿大拼图大师:Puzzle Master
2020/12/28 全球购物
什么情况下你必须要把一个类定义为abstract的
2013/01/06 面试题
产品工艺师的岗位职责
2013/11/15 职场文书
小学班级口号
2014/06/09 职场文书
村支部书记群众路线对照检查材料思想汇报
2014/10/08 职场文书
2014年有孩子的离婚协议书范本
2014/10/08 职场文书
小学工作总结2015
2015/05/04 职场文书
Pytorch数据读取之Dataset和DataLoader知识总结
2021/05/23 Python
golang特有程序结构入门教程
2021/06/02 Python
Android存储中最基本的文件存储方式
2022/04/30 Java/Android