原生JS實(shí)現(xiàn)音樂(lè)播放器
本文實(shí)例為大家分享了JS實(shí)現(xiàn)音樂(lè)播放器的具體代碼,供大家參考,具體內(nèi)容如下
首先,使用HTML搭好我們的框架結(jié)構(gòu)。這一步為了提高我們代碼的可讀性,多寫(xiě)注釋。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>原生JS音樂(lè)播放器</title> <link rel="stylesheet" href="css/public.css" > <link rel="stylesheet" href="css/css.css" > </head> <body> <!-- 音樂(lè)播放器 --> <div class="music"> <!-- 歌曲信息 --> <div class="word"> <div class="clears"></div> <!-- 歌曲封面 --> <div class="img"> <img src="images/1.jpg" id="img" alt="" /></div> <!-- 歌曲封面 end --> </div> <!-- 歌曲信息 end --> <!-- 信息和音量 --> <div class="mtv"> <!-- 文字信息 --> <div class="text"> <h1 id="sName">歌曲名稱</h1> <h2 id="singer">歌手</h2> </div> <!-- 文字信息 end --> <!-- 音量控制 --> <div class="vol01"> <div class="volTop" id="volText"> 100% </div> <div class="volBottom"> <div class="volPro" id="vol"> <div class="volColor" id="volCol"></div> <div class="volBlock" id="volB"></div> </div> <div class="vImg"> <img src="images/音量.png" alt="" /> </div> </div> </div> <!-- 音量控制 end --> </div> <!-- 信息和音量 end --> <!-- 進(jìn)度條 --> <div class="progress"> <span class="cTime time" id="cTime">00:00</span> <!-- 當(dāng)前時(shí)間 --> <span class="tTime time" id="tTime">00:00</span> <!-- 總的時(shí)間 --> <div class="clears"></div> <!-- 進(jìn)度條小 --> <div class="proBar" id="songPro"> <div class="proColor" id="proBar"></div> </div> <!-- 進(jìn)度條小 end --> </div> <!-- 進(jìn)度條 end --> <!-- 控制按鈕 --> <div class="ctrls"> <div class="btn"> <img src="images/prev.png" class="prevBtn" id="prevBtn" alt="" /> <img src="images/next.png" class="nextPrev" id="nextBtn" alt="" /> </div> <button type="button" class="playBtn" id="playBtn"><img src="images/播放.png" alt="" /></button> </div> <!-- 控制按鈕 end --> <audio src="#" id="music"></audio> </div> <!-- 音樂(lè)播放器 end --> <script src="js/js.js"></script> </body> </html>
第二步,搭好框架后,就用CSS給他寫(xiě)上你喜歡的樣式。注意這里我是將樣式分為了公共樣式和獨(dú)立樣式分開(kāi)寫(xiě)的,提高代碼可重復(fù)利用,當(dāng)然你也可以使用SASS更方便,這里我只提供了獨(dú)立樣式,公共樣式可以在網(wǎng)上自主尋找。
html { background: #92b991; } .music { width: 670px; height: 400px; background: url("../images/bg.jpg") no-repeat center; margin-left: auto; margin-right: auto; border: 1px #3d5e59 solid; margin-top: 150px; border-radius: 20px; box-shadow: 0 0 20px rgba(0, 0, 0, 0.3); position: relative; } .img { width: 200px; height: 200px; border: 2px #fff solid; overflow: hidden; border-radius: 100%; margin-top: 50px; margin-left: 35%; } .mtv { width: 670px; position: relative; } .text { color: #fff; margin-right: 30px; margin-left: 30px; margin-bottom: 10px; } .text>h1 { font-size: 24px; line-height: 30px; font-weight: normal; } .text>h2 { font-family: "Microsoft YaHei"; font-size: 14px; font-weight: 300; line-height: 1.7; } .vol01 { position: absolute; height: 30px; width: 120px; right: 30px; top: -8%; } .volPro { width: 100%; height: 5px; margin-top: 44.5px; border: 1px #fff solid; border-radius: 5px; } .volColor { height: 5px; width: 100%; color: #fff; pointer-events: none; } .volBlock { pointer-events: none; position: absolute; top: 42px; width: 10px; height: 10px; border: 1px #fff solid; background: #f4f3f3; border-radius: 100%; left: 100%; margin-left: -5px; } .volTop { color: #fff; font-size: 10px; position: absolute; top: 25px; right: 0; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .vImg { position: absolute; top: 38px; left: -26px; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .time { font-family: "Microsoft YaHei"; font-size: 10px; line-height: 1.5; color: #fff; margin-top: 25px; } .cTime { float: left; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .tTime { float: right; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; } .progress { margin-left: 30px; margin-right: 30px; } .proBar { width: 100%; height: 2px; overflow: hidden; background: #B292FF; margin-top: 5px; border-radius: 5px; } .proColor { height: 7px; width: 30%; background: #fff; pointer-events: none; } .ctrls { text-align: center; margin-top: 20px; margin-left: 30px; margin-right: 30px; } .btn { position: absolute; top: 50px; } .nextPrev { right: 0; margin-left: 200px; opacity: 0.1; transition: all 0.3s; } .nextPrev:hover { opacity: 0.5; } .prevBtn { left: 0; opacity: 0.1; transition: all 0.3s; } .prevBtn:hover { opacity: 0.5; } .playBtn { height: 200px; width: 200px; border-radius: 200px; opacity: 0.3; position: absolute; top: 52px; left: 250px; margin-left: -14px; transition: all 0.3s; } .playBtn:hover { opacity: 0.5; background: #46847b; }
第三步,也是讓音樂(lè)播放器具有靈魂的東西,使用JS添加功能。
1.獲取ID(當(dāng)然這里也可以獲取類名或是元素,看你自己的習(xí)慣)。
let music = document.getElementById("music"); let playBtn = document.getElementById("playBtn"); let prevBtn = document.getElementById("prevBtn"); let nextBtn = document.getElementById("nextBtn"); let img = document.getElementById("img"); let sName = document.getElementById("sName"); let singer = document.getElementById("singer"); let tTime = document.getElementById("tTime"); let proBar = document.getElementById("proBar"); let cTime = document.getElementById("cTime"); let songPro = document.getElementById("songPro"); let vol = document.getElementById("vol"); let volCol = document.getElementById("volCol"); let volB = document.getElementById("volB"); let volText = document.getElementById("volText");
2.添加音樂(lè)播放功能。
導(dǎo)入音樂(lè)
let songs = [{ mp3: "music/01.mp3", singer: "趙薇", name: "不能和你分手", img: "images/1.jpg" }, { mp3: "music/04.mp3", singer: "陳粒", name: "易燃易爆炸", img: "images/2.jpg" }, { mp3: "music/06.mp3", singer: "胡夏/郁可唯", name: "知否知否", img: "images/3.jpg" }];
音樂(lè)播放
let changeMusic = function(index) { music.src = songs[index].mp3; img.src = songs[index].img; sName.innerHTML = songs[index].name; singer.innerHTML = songs[index].singer; proBar.style.width = 0; }; let index = 0; changeMusic(index);
音樂(lè)播放暫停
playBtn.addEventListener("click", function(event) { if (music.paused) { music.play(); event.currentTarget.innerHTML = '<img src="images/暫停.png" alt=""/>'; } else { music.pause(); event.currentTarget.innerHTML = '<img src="images/播放.png" alt=""/>'; } });
音樂(lè)切換
prevBtn.addEventListener("click", function(event) { //上一首 index--; if (index <= -1) { index = songs.length - 1; } changeMusic(index); }); nextBtn.addEventListener("click", function(event) { //下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); }); music.addEventListener('ended',function () { //自動(dòng)播放下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); })
3.添加進(jìn)度條。
music.addEventListener("loadedmetadata", function(event) { //提示音頻的元數(shù)據(jù)已加載 tTime.innerHTML = parseInt(music.duration / 60) + ":" + parseInt(music.duration % 60); }); music.addEventListener("timeupdate", function(event) { //監(jiān)聽(tīng)音樂(lè)事實(shí)播放事件 let jd = music.currentTime / music.duration; let bfb = jd * 100 + "%"; proBar.style.width = bfb; if (music.currentTime < 10) { cTime.innerHTML = "0:0" + Math.floor(music.currentTime); } else if (music.currentTime < 60) { cTime.innerHTML = "0:" + Math.floor(music.currentTime); } else { let minet = parseInt(music.currentTime / 60); let sec = music.currentTime - minet * 60; if (sec < 10) { cTime.innerHTML = "0" + minet + ":" + "0" + parseInt(sec); } else { cTime.innerHTML = "0" + minet + ":" + parseInt(sec); } } });
小功能:點(diǎn)擊進(jìn)度條,音樂(lè)也跟著變化跳轉(zhuǎn)到指定的時(shí)間。
songPro.addEventListener("click", function(event) { let x = event.offsetX; let bfb = x / 610 * 100; proBar.style.width = bfb + "%"; music.currentTime = music.duration * bfb / 100; });
4.添加音量調(diào)節(jié)模塊。
let getBfb = function(event) { let x = event.clientX; //返回當(dāng)事件被觸發(fā)時(shí)鼠標(biāo)指針向?qū)τ跒g覽器頁(yè)面(或客戶區(qū))的水平坐標(biāo)。 let volX = vol.getBoundingClientRect().x; //getBoundingClientRect()獲取元素的寬高位置 let disX = x - volX; disX = Math.max(0, disX); //返回最大數(shù)字 disX = Math.min(120, disX); //返回最小數(shù)字 return disX / 120; }; let setVol = function(event) { let bfb = Math.floor(getBfb(event) * 10000) / 100; volCol.style.width = bfb + "%"; volB.style.left = bfb + "%"; volText.innerHTML = Math.floor(bfb) + "%"; music.volume = bfb / 100; }; vol.addEventListener("mousedown", function() { document.addEventListener("mousemove", setVol); }); document.addEventListener("mouseup", function() { document.removeEventListener("mousemove", setVol); });
全部JS代碼
這里我使用了{(lán)}作用域,讓let 或 const聲明的變量只在 let 或 const命令所在的代碼塊 {} 內(nèi)有效,在 {} 之外不能訪問(wèn)(ECMAScript 6(簡(jiǎn)稱ES6)中新增的)。
{ let music = document.getElementById("music"); let playBtn = document.getElementById("playBtn"); let prevBtn = document.getElementById("prevBtn"); let nextBtn = document.getElementById("nextBtn"); let img = document.getElementById("img"); let sName = document.getElementById("sName"); let singer = document.getElementById("singer"); let tTime = document.getElementById("tTime"); let proBar = document.getElementById("proBar"); let cTime = document.getElementById("cTime"); let songPro = document.getElementById("songPro"); let vol = document.getElementById("vol"); let volCol = document.getElementById("volCol"); let volB = document.getElementById("volB"); let volText = document.getElementById("volText"); let songs = [{ mp3: "music/01.mp3", singer: "趙薇", name: "不能和你分手", img: "images/1.jpg" }, { mp3: "music/04.mp3", singer: "陳粒", name: "易燃易爆炸", img: "images/2.jpg" }, { mp3: "music/06.mp3", singer: "胡夏/譚維維", name: "知否知否", img: "images/3.jpg" }]; let changeMusic = function(index) { music.src = songs[index].mp3; img.src = songs[index].img; sName.innerHTML = songs[index].name; singer.innerHTML = songs[index].singer; proBar.style.width = 0; }; let index = 0; changeMusic(index); playBtn.addEventListener("click", function(event) { if (music.paused) { music.play(); event.currentTarget.innerHTML = '<img src="images/暫停.png" alt=""/>'; } else { music.pause(); event.currentTarget.innerHTML = '<img src="images/播放.png" alt=""/>'; } }); prevBtn.addEventListener("click", function(event) { //上一首 index--; if (index <= -1) { index = songs.length - 1; } changeMusic(index); }); nextBtn.addEventListener("click", function(event) { //下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); }); music.addEventListener('ended',function () { //自動(dòng)播放下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); }) music.addEventListener("loadedmetadata", function(event) { //提示音頻的元數(shù)據(jù)已加載 tTime.innerHTML = parseInt(music.duration / 60) + ":" + parseInt(music.duration % 60); }); music.addEventListener("timeupdate", function(event) { //監(jiān)聽(tīng)音樂(lè)事實(shí)播放事件 let jd = music.currentTime / music.duration; //music.duration總時(shí)長(zhǎng) music.currentTime 當(dāng)前時(shí)長(zhǎng) let bfb = jd * 100 + "%"; proBar.style.width = bfb; if (music.currentTime < 10) { cTime.innerHTML = "0:0" + Math.floor(music.currentTime); //Math.floor()向下取整 } else if (music.currentTime < 60) { cTime.innerHTML = "0:" + Math.floor(music.currentTime); } else { let minet = parseInt(music.currentTime / 60); //parseInt()解析一個(gè)字符串,并返回一個(gè)整數(shù) let sec = music.currentTime - minet * 60; if (sec < 10) { cTime.innerHTML = "0" + minet + ":" + "0" + parseInt(sec); } else { cTime.innerHTML = "0" + minet + ":" + parseInt(sec); } } }); songPro.addEventListener("click", function(event) { let x = event.offsetX; let bfb = x / 610 * 100; proBar.style.width = bfb + "%"; music.currentTime = music.duration * bfb / 100; }); let getBfb = function(event) { let x = event.clientX; //返回當(dāng)事件被觸發(fā)時(shí)鼠標(biāo)指針向?qū)τ跒g覽器頁(yè)面(或客戶區(qū))的水平坐標(biāo)。 let volX = vol.getBoundingClientRect().x; //getBoundingClientRect()獲取元素的寬高位置 let disX = x - volX; disX = Math.max(0, disX); //返回最大數(shù)字 disX = Math.min(120, disX); //返回最小數(shù)字 return disX / 120; }; let setVol = function(event) { let bfb = Math.floor(getBfb(event) * 10000) / 100; volCol.style.width = bfb + "%"; volB.style.left = bfb + "%"; volText.innerHTML = Math.floor(bfb) + "%"; music.volume = bfb / 100; }; vol.addEventListener("mousedown", function() { document.addEventListener("mousemove", setVol); }); document.addEventListener("mouseup", function() { document.removeEventListener("mousemove", setVol); }); }
最終效果展示:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 運(yùn)用js教你輕松制作html音樂(lè)播放器
- js實(shí)現(xiàn)可兼容IE、FF、Chrome、Opera及Safari的音樂(lè)播放器
- JavaScript實(shí)現(xiàn)帶播放列表的音樂(lè)播放器實(shí)例分享
- JavaScript實(shí)現(xiàn)簡(jiǎn)單音樂(lè)播放器
- JS+html5制作簡(jiǎn)單音樂(lè)播放器
- js制作簡(jiǎn)單的音樂(lè)播放器的示例代碼
- js實(shí)現(xiàn)簡(jiǎn)單音樂(lè)播放器
- 原生JS實(shí)現(xiàn)網(wǎng)頁(yè)手機(jī)音樂(lè)播放器 歌詞同步播放的示例
- js+audio實(shí)現(xiàn)音樂(lè)播放器
- js實(shí)現(xiàn)音樂(lè)播放器
相關(guān)文章
bootstrap3中container與container_fluid外層容器的區(qū)別講解
.container與.container_fluid是bootstrap中的兩種不同類型的外層容器。這篇文章主要介紹了bootstrap3中container與container_fluid的區(qū)別,需要的朋友可以參考下2017-12-12javascript實(shí)現(xiàn)在下拉列表中顯示多級(jí)樹(shù)形菜單的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)在下拉列表中顯示多級(jí)樹(shù)形菜單的方法,涉及javascript屬性菜單的定義、構(gòu)造及遍歷等技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08bootstrap模態(tài)框遠(yuǎn)程示例代碼分享
這篇文章主要為大家詳細(xì)介紹了bootstrap模態(tài)框遠(yuǎn)程示例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05JS前端開(kāi)發(fā)判斷是否是手機(jī)端并跳轉(zhuǎn)操作(小結(jié))
這篇文章主要介紹了JS前端開(kāi)發(fā)判斷是否是手機(jī)端并跳轉(zhuǎn)操作,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02小程序組件傳值和引入sass的方法(使用vant Weapp組件庫(kù))
這篇文章主要介紹了小程序組件傳值和引入sass使用vant Weapp組件庫(kù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11JavaScript使用math.js進(jìn)行精確計(jì)算操作示例
這篇文章主要介紹了JavaScript使用math.js進(jìn)行精確計(jì)算操作,結(jié)合實(shí)例形式分析了開(kāi)源庫(kù)math.js進(jìn)行高精度數(shù)學(xué)運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2018-06-06