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 相关文章推荐
不错的新闻标题颜色效果
Dec 10 Javascript
jQuery前台数据获取实现代码
Mar 16 Javascript
Javascript 页面模板化很多人没有使用过的方法
Jun 05 Javascript
js判断浏览器类型为ie6时不执行
Jun 15 Javascript
jQuery 浮动导航菜单适合购物商品类型的网站
Sep 09 Javascript
JavaScript生成二维码图片小结
Dec 27 Javascript
实例剖析AngularJS框架中数据的双向绑定运用
Mar 04 Javascript
EasyUI 结合JS导出Excel文件的实现方法
Nov 10 Javascript
原生JS实现图片无缝滚动方法(附带封装的运动框架)
Oct 01 Javascript
react 实现页面代码分割、按需加载的方法
Apr 03 Javascript
css配合JavaScript实现tab标签切换效果
Oct 11 Javascript
浅析VUE防抖与节流
Nov 24 Vue.js
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 删除cookie和浏览器重定向
2009/03/16 PHP
PHP中extract()函数的妙用分析
2012/07/11 PHP
php单态设计模式(单例模式)实例
2014/11/18 PHP
php metaphone()函数及php localeconv() 函数实例解析
2016/05/15 PHP
php-fpm开启状态统计的方法详解
2017/06/23 PHP
浅谈Laravel核心解读之Console内核
2018/12/02 PHP
jquery.lazyload  实现图片延迟加载jquery插件
2010/02/06 Javascript
新老版本juqery获取radio对象的方法
2010/03/01 Javascript
Node.js中使用Log.io在浏览器中实时监控日志(等同tail -f命令)
2014/09/17 Javascript
解决jQuery uploadify在非IE核心浏览器下无法上传
2015/08/05 Javascript
jQuery on()方法绑定动态元素的点击事件无响应的解决办法
2016/07/07 Javascript
vue中mint-ui环境搭建详细介绍
2017/04/06 Javascript
微信小程序中hidden不生效原因的解决办法
2017/04/26 Javascript
微信小程序之前台循环数据绑定
2017/08/18 Javascript
详解Vue.js中.native修饰符
2018/04/24 Javascript
浅谈vue加载优化策略
2019/03/19 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
2019/05/17 Javascript
vue 函数调用加括号与不加括号的区别
2020/10/29 Javascript
使用Python脚本将Bing的每日图片作为桌面的教程
2015/05/04 Python
Python中线程编程之threading模块的使用详解
2015/06/23 Python
Python实现在线音乐播放器
2017/03/03 Python
详解Python传入参数的几种方法
2019/05/16 Python
使用PyTorch将文件夹下的图片分为训练集和验证集实例
2020/01/08 Python
CSS3 特效范例整理
2011/08/22 HTML / CSS
css3弹性盒子flex实现三栏布局的实现
2020/11/12 HTML / CSS
html5 冒号分隔符对齐的实现
2019/07/31 HTML / CSS
AmazeUI 面板的实现示例
2020/08/17 HTML / CSS
为娇小女性量身打造:Petite Studio
2018/11/01 全球购物
Gretna Green中文官网:苏格兰格林小镇
2019/10/16 全球购物
轻金属冶金专业毕业生自荐信
2013/11/02 职场文书
自荐信格式写作方法有哪些呢
2013/11/20 职场文书
大学生文员专业个人求职信范文
2014/01/05 职场文书
媒体宣传策划方案
2014/05/25 职场文书
学校群众路线专项整治方案
2014/10/31 职场文书
元旦晚会主持词开场白
2015/05/28 职场文书
2019新员工试用期转正申请书3篇
2019/08/13 职场文书