使用vue-aplayer插件时出现的问题的解决

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

使⽤vue-aplayer插件时出现的问题的解决本⽂介绍了使⽤vue-aplayer插件时出现的问题的解决,分享给⼤家,具体如下:
安装
$ npm install vue-aplayer --save
使⽤
<aplayer autoplay :music="{
title: 'Preparation',
author: 'Hans Zimmer/Richard Harvey',
url: '/Preparation.mp3',
pic: '/Preparation.jpg',
lrc: '[00:00.00]lrc here\n[00:01.00]aplayer'
}">
</aplayer>
// ES6
import Aplayer from 'vue-aplayer'
new Vue({
components: {
Aplayer
}
})
属性
这些属性⼤部分跟Aplayer的选项⼀样
属性名类型默认值描述
narrow Boolean false紧凑样式
autoplay String null是否⾃动播放,为null表⽰不会⾃动播放
showlrc Boolean false是否显⽰歌词
mutex Boolean false当⼀⾸⾳乐正在播放时,暂停其他⾳乐
theme String '#b7daff'(浅
蓝⾊)
主题颜⾊
mode String'circulation'播放模式,random:随机模式 sigle:单曲循环circulation:列表循环 order:顺序播放(列表播放完即停⽌)
preload String'auto'⾳乐加载⽅式,none,metadata,auto listmaxheight String none播放列表的最⼤⾼度
music String Object or
Array歌曲信息,详情见下⽅“歌曲信息”
歌曲信息
属性music既可以是包含歌曲信息的对象类型,也可以是包含这些对象的数组类型
属性名默认值描述
title'Untitled'歌曲名
author'Unknown'歌⼿
url required歌曲地址
pic none歌曲海报
lrc none歌词或者歌词⽂件的地址
事件
事件名参数描述
play none开始播放时触发
pause none暂停时触发
canplay none当数据⽀持播放时触发
playing none播放时会定时触发
ended none停⽌播放时触发
error none错误出现时触发
update:mode none见上⾯的mode属性
刚刚接触vue-aplayer,从github上找到了⽤法,⾸先需要npm install vue-aplayer –save ,之后在组件中引⼊import VueAplayer from ‘vue-aplayer',别忘了注册components: { 'a-player': VueAplayer
}
这⾥还有⼀个问题,⽤v-if,⽽不是v-show,因为是异步请求,所以⼀开始播放器中是没有歌曲的,所有给了个v-if不然会插件默认会先⽣成播放器,导致报错
–2017.12.2 ,现在的代码版本是这样的~
<template>
<div class="music">
<a-player v-if='isShow' :autoplay='true' :music="musicList"></a-player>
</div>
</template>
<script>
import Axios from 'axios'
import VueAplayer from 'vue-aplayer'
export default{
data(){
return {
musicList:[],
isShow:false
}
},
mounted(){
Axios.get('../static/data/musicdata.json').then(res=>{
let List = res.data.musicData;
// console.log(res);
List.forEach(element => {
let obj = {
title:element.title,
pic:element.musicImgSrc,
url:element.src,
author:element.author,
lrc:"../static/"+element.lrc
}
this.musicList.push(obj);
});
this.isShow=true;
console.log(this.musicList);
}).catch();
},
components: {
'a-player': VueAplayer
}
}
</script>
<style>
.music{
margin:1rem 0;
}
</style>
还是有问题,⽹上查过之后,是因为在执⾏了play()⽅法以后⽴即执⾏pause()⽅法,⾄于解决⽅法……还在寻找中
之前遇到的问题是
~~~~想明⽩了⼀些
酱紫,this.musicList是空的,obj就是空的喽。

如果先给this.musicList赋值了,那么push之后就会酱紫,重复两遍
其实是很好想明⽩的哈。

补充的代码,看起来更直观
Axios.get('../static/data/musicdata.json').then(res=>{
// let List = res.data.musicData;
// console.log(res);
this.musicList.forEach(element => {
let obj = {
title:element.title,
pic:element.musicImgSrc,
url:element.src,
author:element.author,
lrc:"../static/"+element.lrc
}
this.musicList.push(obj);
console.log(this.musicList);
});
this.isShow=true;
console.log(this.musicList);
}).catch();
错误是这样的
正确的是酱紫的
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

相关文档
最新文档