亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

HTML5網頁音樂播放器的示例代碼

2024-09-05 07:19:06
字體:
來源:轉載
供稿:網友

本文介紹了HTML5網頁音樂播放器的示例代碼,分享給大家,具體如下:

1功能介紹

HTML5中推出了音視頻標簽,可以讓我們不借助其他插件就可以直接播放音視頻。下面我們就利用H5的audio標簽及其相關屬性和方法來制作一個簡單的音樂播放器。主要包括以下幾個功能:

1、播放暫停、上一首和下一首

2、調整音量和播放進度條

3、根據列表切換當前歌曲

先來看一下最終的完成效果:

這個音樂播放器的結構主要分為三部分:歌曲信息、播放器和播放列表,我們重點介紹一下播放器部分。首先在播放器中放三個audio標簽用于播放:

<audio id="music1">瀏覽器不支持audio標簽<source  src="media/Beyond - 光輝歲月.mp3"></source></audio><audio id="music2">瀏覽器不支持audio標簽<source  src="media/Daniel Powter - Free Loop.mp3"></source></audio><audio id="music3">瀏覽器不支持audio標簽<source  src="media/周杰倫、費玉清 - 千里之外.mp3"></source></audio>

下面的播放列表也對應三個audio標簽:

<div id="playList">    <ul>        <li id="m0">Beyond-光輝歲月</li>        <li id="m1">Daniel Powter-Free Loop</li>        <li id="m2">周杰倫、費玉清-千里之外</li>    </ul></div>

接下來我們就開始逐步實現上面提到的功能吧,先來完成播放和暫停功能,在按下播放按鈕時我們要做到進度條隨歌曲進度前進,播放時間也逐漸增加,同時播放按鈕變成暫停按鈕,播放列表的樣式也對應改變。

在做功能之前我們要先把三個audio標簽獲取id后存到一個數組中,供后續使用。

var music1= document.getElementById("music1");var music2= document.getElementById("music2");var music3= document.getElementById("music3");var mList = [music1,music2,music3];

2播放和暫停:

我們現在就可以完成播放按鈕的功能啦,首先設置一個標志,用來標記音樂的播放狀態,再為數組的索引index設置一個默認值:

然后對播放狀態進行判斷,調用對應的函數,并修改flag的值和列表對應項目樣式:

function playMusic(){if(flag&&mList[index].paused){            mList[index].play();        document.getElementById("m"+index).style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";progressBar();        playTimes();        play.style.backgroundImage = "url(media/pause.png)";        flag = false;}else{        mList[index].pause();        flag = true;        play.style.backgroundImage = "url(media/play.png)";}}

上面的代碼中調用了多個函數,其中播放和暫停是audio標簽自帶的方法,而其他的函數則是我們自己定義的。下面我們就來看一下這些函數是怎么實現的,又對應了哪些功能吧。

3進度條和播放時間:

 首先是進度條功能,獲取歌曲的全部時長,然后再根據當前播放的進度與進度條總長度相乘計算出進度條的位置。

function progressBar(){var lenth=mList[index].duration;timer1=setInterval(function(){        cur=mList[index].currentTime;//獲取當前的播放時間        progress.style.width=""+parseFloat(cur/lenth)*300+"px";        progressBtn.style.left= 60+parseFloat(cur/lenth)*300+"px";},10)}

下面是改變播放時間功能,這里我們設置一個定時函數,每隔一段時間來執行一次以改變播放時間。因為我們獲取到的歌曲時長是以秒來計算,所以我們要利用if語句對時長判斷來進行換算,將播放時間改為以幾分幾秒的形式來顯示。

function playTimes(){timer2=setInterval(function(){        cur=parseInt(mList[index].currentTime);//秒數        var minute=parseInt(cur/60);        if (minute<10) {            if(cur%60<10){                playTime.innerHTML="0"+minute+":0"+cur%60+"";            }else{                playTime.innerHTML="0"+minute+":"+cur%60+"";            }        } else{            if(cur%60<10){                playTime.innerText= minute+":0"+cur%60+"";            }else{                playTime.innerText= minute+":"+cur%60+"";            }         } },1000);}

4調整播放進度和音量:

接下來我們再來完成一下通過進度條調整播放進度和調整音量功能。

調整播放進度功能利用了event對象來實現,因為offsetX屬性只有IE事件具有,所以推薦使用IE瀏覽器查看效果。先對進度條添加事件監聽,當在進度條上點擊鼠標時,獲取鼠標的位置,并根據位置除以進度條的總長度來計算當前的播放進度,然后對歌曲進行設置。

//調整播放進度total.addEventListener("click",function(event){var e = event || window.event;document.onmousedown = function(event){        var e = event || window.event;        var mousePos1 = e.offsetX;        var maxValue1 = total.scrollWidth;        mList[index].currentTime = (mousePos1/300)*mList[index].duration;        progress.style.width = mousePos1+"px";        progressBtn.style.left = 60+ mousePos1 +"px";}})

下面是調整音量功能,音量的調整我們采用拖動的形式實現,思路也是對音量條的按鈕球添加事件監聽,然后根據拖動的位置來計算按鈕球相對于音量條整體的位置,最后根據計算結果與音量相乘得出當前音量:

volBtn.addEventListener("mousedown",function(event){var e = event || window.event;var that =this;//阻止球的默認拖拽事件e.preventDefault();document.onmousemove = function(event){var e = event || window.event;var mousePos2 = e.offsetY;var maxValue2 = vol.scrollHeight;if(mousePos2<0){            mousePos2 = 0;}if(mousePos2>maxValue2){            mousePos2=maxValue2;}mList[index].volume = (1-mousePos2/maxValue2);console.log(mList[index].volume);volBtn.style.top = (mousePos2)+"px";volBar.style.height = 60-(mousePos2)+"px";document.onmouseup = function(event){            document.onmousemove = null;            document.onmouseup = null;}}})

5歌曲切換

 最后我們再來實現比較復雜的歌曲切換功能。

先來看用上一首和下一首按鈕進行切換,在切換音樂時我們要注意的問題有下面幾個:第一,我們要停止當前播放的音樂,轉而播放下一首音樂;第二,要清空進度條和播放時間,重新計算;第三,歌曲信息要隨之改變,播放器下面的播放列表樣式也要變化。在弄清楚上面三點以后我們就可以開始實現功能了。

//上一曲function prevM(){clearInterval(timer1);clearInterval(timer2);stopM();qingkong();cleanProgress();--index;if(index==-1){        index=mList.length-1;}clearListBgc();document.getElementById("m"+index).style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";changeInfo(index);mList[index].play();progressBar();playTimes();if (mList[index].paused) {    play.style.backgroundImage = "url(media/play.png)";}else{    play.style.backgroundImage = "url(media/pause.png)";}} //下一曲function nextM(){clearInterval(timer1);clearInterval(timer2);stopM();qingkong();cleanProgress();++index;if(index==mList.length){    index=0;}clearListBgc();document.getElementById("m"+index).style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";changeInfo(index);mList[index].play();progressBar();playTimes();if (mList[index].paused) {    play.style.backgroundImage = "url(media/play.png)";}else{    play.style.backgroundImage = "url(media/pause.png)";}}

下面的代碼是點擊列表切換歌曲。

m0.onclick = function (){clearInterval(timer1);clearInterval(timer2);qingkong();flag = false;stopM();index = 0;pauseall();play.style.backgroundImage = "url(media/pause.png)";clearListBgc();document.getElementById("m0").style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";mList[index].play();cleanProgress();progressBar();changeInfo(index);playTimes();}m1.onclick = function (){clearInterval(timer1);clearInterval(timer2);flag = false;qingkong();stopM();index = 1;pauseall();clearListBgc();play.style.backgroundImage = "url(media/pause.png)";document.getElementById("m1").style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";mList[index].play();cleanProgress();changeInfo(index);progressBar();playTimes();}m2.onclick = function (){clearInterval(timer1);clearInterval(timer2);flag = false;qingkong();stopM();index = 2;pauseall();play.style.backgroundImage = "url(media/pause.png)";clearListBgc();document.getElementById("m2").style.backgroundColor = "#A71307";document.getElementById("m"+index).style.color = "white";mList[index].play();cleanProgress();changeInfo(index);progressBar();playTimes();}

通過播放列表來切換歌曲與通過按鈕切換的思路差不多,只是根據對應的列表項來設置當前應該播放哪首歌曲。

上面切換歌曲的函數中都調用了幾個方法,下面我們來看看這些方法的用途都是什么吧。

首先是切換歌曲信息:

function changeInfo(index){if (index==0) {    musicName.innerHTML = "光輝歲月";    singer.innerHTML = "Beyond";}if (index==1) {    musicName.innerHTML = "Free Loop";    singer.innerHTML = "Daniel Powter";}if (index==2) {    musicName.innerHTML = "千里之外";    singer.innerHTML = "周杰倫、費玉清";}} 

然后清空兩個定時器:

//將進度條置0function cleanProgress(timer1){if(timer1!=undefined){    clearInterval(timer1);}progress.style.width="0";progressBtn.style.left="60px";} function qingkong(timer2){ if(timer2!=undefined){    clearInterval(timer2);}}

再把播放的音樂停止,并且將播放時間恢復。

function stopM(){if(mList[index].played){    mList[index].pause();    mList[index].currentTime=0;    flag=false;}}

最后的最后,改變下面播放列表的樣式:

function clearListBgc(){document.getElementById("m0").style.backgroundColor = "#E5E5E5";document.getElementById("m1").style.backgroundColor = "#E5E5E5";document.getElementById("m2").style.backgroundColor = "#E5E5E5";document.getElementById("m0").style.color = "black";document.getElementById("m1").style.color = "black";document.getElementById("m2").style.color = "black";}

到此,音樂播放器我們就基本完成了,來看一下動圖的效果:

作者:杰瑞教育
出處:http://www.cnblogs.com/jerehedu/ 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合色综合网色综合| 国产精品青草久久久久福利99| 国产999在线| 精品国产视频在线| 欧美性生活大片免费观看网址| 狠狠久久五月精品中文字幕| 成人免费福利视频| 欧美一区二区三区精品电影| 成人午夜在线视频一区| 97在线视频国产| 欧美激情xxxx性bbbb| 久久资源免费视频| 亚洲欧美日韩天堂一区二区| 久久艳片www.17c.com| 欧美亚洲国产视频| 欧美大片在线免费观看| 欧美大片欧美激情性色a∨久久| 日本成人黄色片| 亚洲欧美在线免费| 色偷偷av亚洲男人的天堂| 久热精品视频在线免费观看| 日韩中文字幕在线视频播放| 精品色蜜蜜精品视频在线观看| 在线日韩欧美视频| 国产成人一区二| 国产一区二区三区视频在线观看| 九九热这里只有精品6| 91爱爱小视频k| 亚洲欧美日韩精品久久| 日韩av免费看| 欧美夜福利tv在线| 操日韩av在线电影| 中文字幕日韩精品在线观看| 欧美在线一级视频| 久久久精品美女| 国产一区私人高清影院| 日本精品久久电影| 久久99亚洲热视| 在线观看精品国产视频| 欧美午夜精品久久久久久人妖| 日韩精品免费视频| 欧美精品成人91久久久久久久| 日av在线播放中文不卡| 555www成人网| 九九热最新视频//这里只有精品| 日韩欧美在线第一页| 久久久伊人欧美| 日韩精品久久久久久久玫瑰园| 精品中文字幕乱| 久久久精品国产| 久久免费高清视频| 精品中文字幕在线观看| 欧美激情xxxx性bbbb| 久久亚洲欧美日韩精品专区| 欧美黑人又粗大| 国产精品自产拍在线观看| 亚洲曰本av电影| 欧美疯狂xxxx大交乱88av| 色综合久久久久久中文网| 亚洲男人第一av网站| 在线观看久久久久久| 一个人www欧美| 91在线国产电影| 欧美日韩免费区域视频在线观看| 正在播放欧美一区| 精品国产视频在线| 久久久之久亚州精品露出| 日本欧美一级片| 国产精品一区二区3区| 久久人人爽人人爽人人片av高清| 日韩精品久久久久久福利| 久久久精品电影| 国产人妖伪娘一区91| 成人精品福利视频| 亚洲va欧美va在线观看| 在线播放日韩欧美| 欧美在线视频观看免费网站| 国产女精品视频网站免费| 日韩av片永久免费网站| 亚洲性av网站| 欧美性生交xxxxx久久久| 在线观看日韩www视频免费| 国产91在线播放九色快色| 免费不卡在线观看av| 亚洲自拍偷拍在线| 91成人国产在线观看| 精品丝袜一区二区三区| 精品成人乱色一区二区| xxx欧美精品| 中文字幕在线看视频国产欧美在线看完整| 97国产成人精品视频| 国产精品最新在线观看| 欧美精品情趣视频| 精品毛片三在线观看| 欧美成人精品h版在线观看| 欧美老少做受xxxx高潮| 911国产网站尤物在线观看| 欧美色播在线播放| 日韩中文理论片| 热久久视久久精品18亚洲精品| 亚洲视频在线观看视频| 欧美香蕉大胸在线视频观看| 亚洲美女中文字幕| 欧洲亚洲在线视频| 国产成+人+综合+亚洲欧洲| 欧美激情亚洲国产| 成人妇女淫片aaaa视频| 九九久久久久99精品| 亚洲韩国欧洲国产日产av| 国产精品久久久久久影视| 亚洲成人xxx| 亚洲综合一区二区不卡| 青青久久aⅴ北条麻妃| 欧美xxxx做受欧美.88| 精品国产一区二区三区久久狼5月| 国产经典一区二区| 国产色婷婷国产综合在线理论片a| 欧美成人午夜影院| 亚洲免费伊人电影在线观看av| 欧美另类精品xxxx孕妇| 欧美日韩福利电影| 亚洲精品综合精品自拍| 91av在线免费观看视频| 欧美精品激情在线观看| 成人精品一区二区三区电影免费| 亚洲亚裔videos黑人hd| 日韩在线视频二区| 欧美怡红院视频一区二区三区| 国产精品亚洲视频在线观看| 欧美亚洲国产精品| 中文字幕自拍vr一区二区三区| 欧美精品电影在线| 国产亚洲xxx| 亚洲毛片在线看| 亚洲第一福利视频| 日韩av片电影专区| 欧美日韩在线视频一区二区| 7777kkkk成人观看| 久久精品色欧美aⅴ一区二区| 中文字幕无线精品亚洲乱码一区| 91精品久久久久久久久中文字幕| 久久精品久久久久| 成人久久久久久久| 亚洲精品日韩丝袜精品| 国产精品成人播放| 一夜七次郎国产精品亚洲| 日韩av中文字幕在线播放| 狠狠色香婷婷久久亚洲精品| 欧美一区二区视频97| 国产精品jizz在线观看麻豆| 欧美午夜xxx| 精品亚洲夜色av98在线观看| 色综合色综合久久综合频道88| 午夜精品一区二区三区在线播放| 国产成人+综合亚洲+天堂| 午夜免费在线观看精品视频| 亚洲福利视频久久| 亚洲香蕉在线观看| 日韩中文在线观看| 欧美性视频在线| 精品色蜜蜜精品视频在线观看| 日韩在线免费视频观看| 日本一区二区三区四区视频| 亚洲人线精品午夜|