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 相关文章推荐
JQuery 构建客户/服务分离的链接模型中Table中的排序分析
Jan 22 Javascript
奉献给JavaScript初学者的编写开发的七个细节
Jan 11 Javascript
解析Jquery中如何把一段html代码动态写入到DIV中(实例说明)
Jul 09 Javascript
js处理json以及字符串的比较等常用操作
Sep 08 Javascript
js替代copy(示例代码)
Nov 27 Javascript
JavaScript 学习笔记之变量及其作用域
Jan 14 Javascript
js绘制圆形和矩形的方法
Aug 05 Javascript
javascript 单例模式详解及简单实例
Feb 14 Javascript
使用Bootstrap + Vue.js实现添加删除数据示例
Feb 27 Javascript
BootStrap的两种模态框方式
May 10 Javascript
vue裁切预览组件功能的实现步骤
May 04 Javascript
javascript操作向表格中动态加载数据
Aug 27 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
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2016/09/11 PHP
PHP PDO和消息队列的个人理解与应用实例分析
2019/11/25 PHP
某页码显示的helper 少量调整,另附js版
2010/09/12 Javascript
jquery异步请求实例代码
2011/06/21 Javascript
Jquery右下角抖动、浮动 实例代码(兼容ie6、FF)
2013/08/15 Javascript
基于jquery的手风琴图片展示效果实现方法
2014/12/16 Javascript
javascript封装的sqlite操作类实例
2015/07/17 Javascript
jQuery实现的超链接提示效果示例【附demo源码下载】
2016/09/09 Javascript
JS库之Three.js 简易入门教程(详解之一)
2017/09/13 Javascript
switchery按钮的使用方法
2017/12/18 Javascript
Angular实现的内置过滤器orderBy排序与模糊查询功能示例
2017/12/29 Javascript
如何使用less实现随机下雪动画详解
2019/01/02 Javascript
vue项目添加多页面配置的步骤详解
2019/05/22 Javascript
Python实现将文本生成二维码的方法示例
2017/07/18 Python
python虚拟环境virtualenv的使用教程
2017/10/20 Python
Python读写/追加excel文件Demo分享
2018/05/03 Python
python 自动批量打开网页的示例
2019/02/21 Python
pandas删除指定行详解
2019/04/04 Python
Python 元组操作总结
2019/09/18 Python
Python使用tkinter模块实现推箱子游戏
2019/10/08 Python
解决Python import .pyd 可能遇到路径的问题
2021/03/04 Python
CSS3教程:background-clip和background-origin
2008/10/17 HTML / CSS
英国袜子店:Sock Shop
2017/01/11 全球购物
英国助听器购物网站:Hearing Direct
2018/08/21 全球购物
阿联酋航空丹麦官方网站:Emirates DK
2019/08/25 全球购物
主管竞聘书范文
2014/03/31 职场文书
社区文艺活动方案
2014/08/19 职场文书
四风问题个人对照检查材料
2014/09/26 职场文书
寒暑假实习证明书模板
2014/11/29 职场文书
高校教师个人工作总结2014
2014/12/17 职场文书
钢琴师观后感
2015/06/12 职场文书
青年文明号创建口号大全
2015/12/25 职场文书
《富饶的西沙群岛》教学反思
2016/02/16 职场文书
Vue过滤器(filter)实现及应用场景详解
2021/06/15 Vue.js
mysql优化之query_cache_limit参数说明
2021/07/01 MySQL
java中用float时,数字后面加f,这样是为什么你知道吗
2021/09/04 Java/Android