この記事では、vue-aplayer プラグインを使用する際に発生する問題の解決策を主に紹介しますので、参考にしてください。
この記事では、vue-aplayer プラグインを使用するときに発生する問題の解決策を紹介したいと思います。詳細は次のとおりです。
属性
これらの属性のほとんどはAplayerの属性と同じです
属性名タイプ
デフォルト値
説明
|
| 狭い | ブール | false
コンパクトスタイル
| autoplay | String | null | はい 自動的に再生します。nullは自動的に再生されないことを意味します
| showlrc | ブール | false | 歌詞を表示するかどうか
| ミューテックス | ブール | false | 音楽の再生中に他の音楽を一時停止
| テーマ | 文字列 | '#b7daff' (水色) | テーマカラー
| モード | 文字列 | 'circulation' | 再生モード、ランダム: ランダムモード 単一: シングルループ循環: リストサイクル順序: 順次再生 (リストが再生された後に停止)
| プリロード | 文字列 | 'auto' | 音楽読み込みメソッド、なし、メタデータ、自動
| listmaxheight | String | none | プレイリストの最大高さ
| music | String | Object or Array | 曲情報、「曲情報」を参照詳細は以下をご覧ください
|
| 曲情報 |
属性音楽には曲を含めることができます情報のオブジェクトタイプ、またはこれらのオブジェクトを含む配列タイプ |
属性名デフォルト値
説明
| タイトル | 「無題」 | 曲名
作者 | 「Unknown」 | 歌手 |
url | 必須 | 曲アドレス |
写真 | なし | 歌ポスター |
lrc | なし | 歌詞または歌詞ファイルのアドレス |
| イベント |
|
イベント名
パラメータ説明
| プレイ | なし | トリガー再生開始時
使用中 | なし | 一時停止時にトリガー |
再生可能 | なし | データが再生をサポートしている場合にトリガー |
再生中 | なし | プレイ中に定期的にトリガーされます |
終了 | なし | プレイを停止するとトリガーされます |
エラー | なし | エラーが発生したときにトリガーされます |
update:mode | なし | 上記の 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>
<p class="music">
<a-player v-if='isShow' :autoplay='true' :music="musicList"></a-player>
</p>
</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();
ログイン後にコピー
错误是这样的
正确的是酱紫的
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
通过在vue项目中使用ueditor(详细教程)
通过在vue项目中引入noVNC远程桌面的方法步骤有哪些
利用nodejs爬虫使用superagent和cheerio的方法
以上がvue-aplayer プラグイン使用時のいくつかの問題を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。