温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2021-06-28 09:59:05 来源:亿速云 阅读:234 作者:小新 栏目:web开发

这篇文章主要介绍如何解决使用vue-aplayer插件时出现的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

具体如下:

安装

$ npm install vue-aplayer --save

使用

<aplayer autoplay :music="{  title: 'Preparation',  author: 'Hans Zimmer/Richard Harvey',  url: 'http://devtest.qiniudn.com/Preparation.mp3',  pic: 'http://devtest.qiniudn.com/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的选项一样

属性名类型默认值描述
narrowBooleanfalse紧凑样式
autoplayStringnull是否自动播放,为null表示不会自动播放
showlrcBooleanfalse是否显示歌词
mutexBooleanfalse当一首音乐正在播放时,暂停其他音乐
themeString'#b7daff'(浅蓝色)主题颜色
modeString'circulation'播放模式,random:随机模式 sigle:单曲循环 circulation:列表循环 order:顺序播放(列表播放完即停止)
preloadString'auto'音乐加载方式,none,metadata,auto
listmaxheightStringnone播放列表的最大高度
musicStringObject or Array歌曲信息,详情见下方“歌曲信息”

歌曲信息

属性music既可以是包含歌曲信息的对象类型,也可以是包含这些对象的数组类型

属性名默认值描述
title'Untitled'歌曲名
author'Unknown'歌手
urlrequired歌曲地址
picnone歌曲海报
lrcnone歌词或者歌词文件的地址

事件

事件名参数描述
playnone开始播放时触发
pausenone暂停时触发
canplaynone当数据支持播放时触发
playingnone播放时会定时触发
endednone停止播放时触发
errornone错误出现时触发
update:modenone见上面的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()方法,至于解决方法……还在寻找中

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

之前遇到的问题是

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

~~~~想明白了一些

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

酱紫,this.musicList是空的,obj就是空的喽。

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

如果先给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();

错误是这样的

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

正确的是酱紫的

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

以上是“如何解决使用vue-aplayer插件时出现的问题”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI