用最简略的前端技术制作一个简约的音乐播放器
发布时间:09/01 来源:未知 浏览:
关键词:
这个播放器的音乐是通过豆瓣FM的API猎取到的,我们可以随机的听到豆瓣FM的任何音乐。
html部分
代码:
<div class="wrapper"> <div class="background"></div> <div class="content"> <audio src=""></audio> <div class="music-massage"> <p class="musicname"></p> <p class="musicer"></p> </div> <div class="music-icon"> <a class="m-icon m-fenxiang colored" href="http://service.weibo.com/share/share.php?title=#_loginLayer_1466697157538" target="new"></a> <span class="m-icon m-star colored"></span> <span class="m-icon m-heart colored"></span> </div> </div> <span class="basebar"> <span class="progressbar"></span> </span> <div class="controls"> <div class="play-control"> <span class="m-icon m-play btn1" title="播放/暂停"></span> <span class="m-icon m-change btn2" title="换频道"></span> <span class="m-icon m-next btn3" title="换曲"></span> </div> <div class="music-control"> <span class="m-icon m-xunhuan colored"></span> <span class="m-icon m-radom colored"></span> </div> </div> </div>
这里就不写css的代码了,大家可以直接看源文件或者从开发者工具中去看。假如有问题可以私聊我。
js部分
代码一(播放操纵):
//播放操纵 var myAudio = $("audio")[0]; // 播放/暂停操纵 $(".btn1").click(function(){ if (myAudio.paused) { play() } else { pause() } }); // 频道切换 $(".btn2").click(function(){ getChannel(); }); // 播放下一曲音乐 $(".btn3").click(function(){ getmusic(); }); function play(){ myAudio.play(); $('.btn1').removeClass('m-play').addClass('m-pause'); } function pause(){ myAudio.pause(); $('.btn1').removeClass('m-pause').addClass('m-play'); }
代码二(ajax猎取豆瓣fm音乐):
//猎取随机频道信息 function getChannel(){ $.ajax({ url: 'http://api.jirengu.com/fm/getChannels.php', dataType: 'json', Method: 'get', success: function(response){ var channels = response.channels; var num = Math.floor(Math.random()*channels.length); var channelname = channels[num].name;//猎取随机频道的名称 var channelId = channels[num].channel_id;//猎取随机频道ID $('.record').text(channelname); $('.record').attr('title',channelname); $('.record').attr('data-id',channelId);//将频道ID计入data-id中 getmusic(); } }) } // 通过ajax猎取歌曲 function getmusic(){ $.ajax({ url: 'http://api.jirengu.com/fm/getSong.php', dataType: 'json', Method: 'get', data:{ 'channel': $('.record').attr('data-id') }, success: function (ret) { var resource = ret.song[0], url = resource.url, bgPic = resource.picture, sid = resource.sid,//猎取歌词的参数 ssid = resource.ssid,//猎取歌词的参数 title = resource.title, author = resource.artist; $('audio').attr('src',url); $('.musicname').text(title); $('.musicname').attr('title',title) $('.musicer').text(author); $('.musicer').attr('title',author) $(".background").css({ 'background':'url('+bgPic+')', 'background-repeat': 'no-repeat', 'background-position': 'center', 'background-size': 'cover', }); play();//播放 } }) };
留意:豆瓣会限制我们的拜访,所以在<head>标签下必然要增加<meta name="referrer" content="no-referrer">
代码三(进度条操纵):
setInterval(present,500) //每0.5秒运算进度条长度 $(".basebar").mousedown(function(ev){ //拖拽进度条操纵进度 var posX = ev.clientX; var targetLeft = $(this).offset().left; var percentage = (posX - targetLeft)/400100; myAudio.currentTime = myAudio.duration * percentage/100; }); function present(){ var length = myAudio.currentTime/myAudio.duration100; $('.progressbar').width(length+'%');//设定进度条长度 //主动下一曲 if(myAudio.currentTime == myAudio.duration){ getmusic() } }
html5中audio标签本身供给进度条功效,乃至音量操纵功效的,这里我为了界面的好看本人设定了进度条,音量操纵还没有加,大家可以自行增加。
信赖看了本案牍例你已经把握了办法,更多出色请关注百分百源码网其它相关文章!
相关阅读:
怎样让阅读器变成编纂器
怎样使用python来推断图片类似度
用来下载图片的javascript足本
以上就是用最简便的前端技术制作一个简约的音乐播放器的具体内容,更多请关注百分百源码网其它相关文章!