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 相关文章推荐
baidu博客的编辑友情链接的新的层窗口!经典~支持【FF】
Feb 09 Javascript
window.onload 加载完毕的问题及解决方案(下)
Jul 09 Javascript
基于node.js的快速开发透明代理
Dec 25 Javascript
js获取ajax返回值代码
Apr 30 Javascript
关闭时刷新父窗口两种方法
May 07 Javascript
TinyMCE提交AjaxForm获取不到数据的解决方法
Mar 05 Javascript
js实现常用排序算法
Aug 09 Javascript
Javascript 6里的4个新语法
Aug 25 Javascript
Javascript 动态改变imput type属性
Nov 01 Javascript
vue.js入门(3)——详解组件通信
Dec 02 Javascript
JavaScript实现小球沿正弦曲线运动
Sep 07 Javascript
解决layer.confirm选择完之后消息框不消失的问题
Sep 16 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
了解Joomla 这款来自国外的php网站管理系统
2010/03/11 PHP
input file获得文件根目录简单实现
2013/04/26 PHP
PHP内置过滤器FILTER使用实例
2014/06/25 PHP
PHP递归复制、移动目录的自定义函数分享
2014/11/18 PHP
PHP中list()函数用法实例简析
2016/01/08 PHP
php实现的一段简单概率相关代码
2016/05/30 PHP
Mac系统下搭建Nginx+php-fpm实例讲解
2020/12/15 PHP
jquery创建表格(自动增加表格)代码分享
2013/12/25 Javascript
jquery实现非叠加式的搜索框提示效果
2014/01/07 Javascript
使用jQuery实现图片遮罩半透明坠落遮挡
2015/03/16 Javascript
个人总结的一些JavaScript技巧、实用函数、简洁方法、编程细节
2015/06/10 Javascript
使用Meteor配合Node.js编写实时聊天应用的范例
2015/06/23 Javascript
javascript中setAttribute()函数使用方法及兼容性
2015/07/19 Javascript
jQuery+jsp下拉框联动获取本地数据的方法(附源码)
2015/12/03 Javascript
原生JS实现自定义滚动条效果
2020/10/27 Javascript
JS简单实现点击跳转登陆邮箱功能的方法
2017/10/31 Javascript
js 提取某()特殊字符串长度的实例
2017/12/06 Javascript
js阻止默认右键的下拉菜单方法
2018/01/02 Javascript
小程序视频或音频自定义可拖拽进度条的示例代码
2018/09/30 Javascript
微信小程序自定义tabBar在uni-app的适配详解
2019/09/30 Javascript
[55:26]DOTA2-DPC中国联赛 正赛 Aster vs LBZS BO3 第一场 2月23日
2021/03/11 DOTA
python编程培训 python培训靠谱吗
2018/01/17 Python
python框架中flask知识点总结
2018/08/17 Python
Python自定义函数计算给定日期是该年第几天的方法示例
2019/05/30 Python
python自定义函数实现最大值的输出方法
2019/07/09 Python
python之yield和Generator深入解析
2019/09/18 Python
pyecharts绘制中国2020肺炎疫情地图的实例代码
2020/02/12 Python
解决python cv2.imread 读取中文路径的图片返回为None的问题
2020/06/02 Python
HTML5 Canvas 实现圆形进度条并显示数字百分比效果示例
2017/08/18 HTML / CSS
幼教个人求职信范文
2013/12/02 职场文书
会展策划与管理专业大学生职业生涯规划
2014/02/07 职场文书
法制宣传月活动方案
2014/05/11 职场文书
班主任寄语2015
2015/02/26 职场文书
导游词之大雁塔景区
2019/09/17 职场文书
关于Python OS模块常用文件/目录函数详解
2021/07/01 Python
python playwrigh框架入门安装使用
2022/07/23 Python