vue一个页面实现音乐播放器的示例
前端之家收集整理的这篇文章主要介绍了
vue一个页面实现音乐播放器的示例,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
本文介绍了vue一个页面实现音乐播放器的示例,分享给大家,具体如下:
效果如下:
歌曲资源
爬下接口
直接去虾米官网打开network,将url复制到postman里面去做请求。通过修改headers发现,会校验Referer。也就是说只有虾米允许的域名可以访问此接口。 http://api.xiami.com/web?v=2.0&app_key=1&key=aliez&page=1&limit=5&callback=jsonp154&r=search/songs
因为接口支持jsonp。起初尝试将chrome浏览器设置跨域,然后通过$.ajax去做一个jsonp的请求。可以正常访问。
之后突然不行了,是不是虾米做了限制?
遂改用node启动一个服务,去伪造referer发起请求,再将请求转发到页面。无意中写了一个代理。
歌词滚动
作为一款逼格比较高的播放器,歌词滚动是必须的。
原理
将每一句歌词保存为一个对象,有对应的时间。当歌曲播放的当前时长大于或等于歌词的时间,小于此歌词的下一句歌词的时间,那么就将此歌词滚动到可视区域。并且修改字体颜色。
格式化歌词
接口返回的歌词一脸懵逼,仔细研究一下,发现是有规律的。
aLIEz <199>- <451>SawanoHiroyuki[nZk]:mizuki
[x-trans]彻头彻尾的谎言 - SawanoHiroyuki[nZk]:mizuki
[00:01.095]<201>作<250>詞<200>:<201>澤<200>野<199>弘<300>之
[x-trans]
[00:02.846]<200>作<150>曲<150>:<200>澤<200>野<351>弘<349>之
[x-trans]
[00:20.828]<200>決<250>め<200>つ<201>け<149>ば<201>か<349>り
[x-trans]一直独断专权
[00:23.279]<200>自<200>惚<200>れ<200>を<200>着<400>た
[x-trans]总是自负逞强
[00:24.979]<200>チ<200>ー<200>プ<450>な<550>hokori<350>で
[x-trans]明明只是一文不值的骄傲
......
refactoringLyrics(lyric){
let text = lyric.split('[offset:0]')[1];
let textArr = text.split('\n');
let lyricsArr = [],translate = [];
textArr.forEach((item,index) => {
let time = 0,text = '';
if (item.indexOf('[x-trans]') > -1) {
translate.push(item.split('[x-trans]')[1])
} else if (item.trim() != '') {
time = item.slice(1,6).split(':');
time = parseInt(time[0]) * 60 + parseInt(time[1]);
text = item.slice(11);
let arr = text.split('>');
let str = arr.reduce((a,b) => {
return a.split('<')[0] + b.split('<')[0]
});
let obj = {
time: time,text: str
};
lyricsArr.push(obj);
}
});
for (let i in translate) {
lyricsArr[i].text = lyricsArr[i].text + '\n' + translate[i];
}
this.currentLyrics = lyricsArr;
},
同文件下子组件挂载
为了遵循模块化开发,决定将搜索栏写成一个子组件。在同一页面下写子组件,子组件挂载到对应的template就有讲究了。此template不能被父组件的挂载元素包含,否则父组件渲染时会因为无法渲染子组件中的数据而报undefined。
Box">
...
var searchBox = {
template: '#search-Box',props: {
isShow: Boolean,openFun: Function
},data(){
return {
resultList: [],searchValue: '',}
},methods: {
}
};
new Vue({
el: '#app',components: {
'com-tip': tip,'search-Box': searchBox
},...
})
eventBus解决数据传输
通过jsonp去请求数据,需要设置一个callback函数,此callback写成一个全局函数,如果不这样写,而是通过 searchBox.methods.callback的形式,this指向将为methods。而无法直接给searchBox的data赋值。 于是通过eventBus来处理,这样更易维护。
localh3储存歌曲信息
下次再打开,应该播放列表应该保留上一次的数据,这个可直接用localh3实现
踩了坑
prop传递数据
使用cdn,vue的prop只支持中线格式,驼峰格式不生效
ps: 在用webpack打包的项目中用驼峰是可以,在打包过程中,会做处理。
Box :is-show="showSearch" :open-fun="openSearch" @push-song="pushNewSong"
@play-song="playSong">
//
错误写法
Box :isShow="showSearch" :openFun="openSearch" @pushSong="pushNewSong"
@playSong="playSong">
待优化
手动修改进度,偶尔会不生效。
搜索暂不支持分页
不支持建歌单
背景颜色与进度条颜色相近需修改进度条颜色
不支持播放模式选择-单曲循环-随机播放
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。