日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

原生JS實現音樂播放器

瀏覽:193日期:2024-04-06 15:27:22

本文實例為大家分享了JS實現音樂播放器的具體代碼,供大家參考,具體內容如下

首先,使用HTML搭好我們的框架結構。這一步為了提高我們代碼的可讀性,多寫注釋。

<!DOCTYPE html><html lang='en'> <head> <meta charset='UTF-8'> <title>原生JS音樂播放器</title> <link rel='stylesheet' href='http://www.b3g6.com/bcjs/css/public.css' > <link rel='stylesheet' href='http://www.b3g6.com/bcjs/css/css.css' > </head> <body> <!-- 音樂播放器 --> <div class='music'> <!-- 歌曲信息 --> <div class='word'> <div class='clears'></div> <!-- 歌曲封面 --> <div class='img'> <img src='http://www.b3g6.com/bcjs/images/1.jpg' 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 id='volText'> 100% </div> <div class='volBottom'> <div id='vol'> <div id='volCol'></div> <div id='volB'></div> </div> <div class='vImg'> <img src='http://www.b3g6.com/bcjs/images/音量.png' alt='' /> </div> </div> </div> <!-- 音量控制 end --> </div> <!-- 信息和音量 end --> <!-- 進度條 --> <div class='progress'> <span id='cTime'>00:00</span> <!-- 當前時間 --> <span id='tTime'>00:00</span> <!-- 總的時間 --> <div class='clears'></div> <!-- 進度條小 --> <div id='songPro'> <div id='proBar'></div> </div> <!-- 進度條小 end --> </div> <!-- 進度條 end --> <!-- 控制按鈕 --> <div class='ctrls'> <div class='btn'> <img src='http://www.b3g6.com/bcjs/images/prev.png' alt='' /> <img src='http://www.b3g6.com/bcjs/images/next.png' alt='' /> </div> <button type='button' id='playBtn'><img src='http://www.b3g6.com/bcjs/images/播放.png' alt='' /></button> </div> <!-- 控制按鈕 end --> <audio src='http://www.b3g6.com/bcjs/14207.html#' id='music'></audio> </div> <!-- 音樂播放器 end --> <script src='http://www.b3g6.com/bcjs/js/js.js'></script> </body></html>

第二步,搭好框架后,就用CSS給他寫上你喜歡的樣式。注意這里我是將樣式分為了公共樣式和獨立樣式分開寫的,提高代碼可重復利用,當然你也可以使用SASS更方便,這里我只提供了獨立樣式,公共樣式可以在網上自主尋找。

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;}

第三步,也是讓音樂播放器具有靈魂的東西,使用JS添加功能。

1.獲取ID(當然這里也可以獲取類名或是元素,看你自己的習慣)。

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.添加音樂播放功能。

導入音樂

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='http://www.b3g6.com/bcjs/images/暫停.png' alt=''/>’; } else { music.pause(); event.currentTarget.innerHTML = ’<img src='http://www.b3g6.com/bcjs/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 () { //自動播放下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); })

3.添加進度條。

music.addEventListener('loadedmetadata', function(event) { //提示音頻的元數據已加載 tTime.innerHTML = parseInt(music.duration / 60) + ':' + parseInt(music.duration % 60); }); music.addEventListener('timeupdate', function(event) { //監聽音樂事實播放事件 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); } } });

小功能:點擊進度條,音樂也跟著變化跳轉到指定的時間。

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.添加音量調節模塊。

let getBfb = function(event) { let x = event.clientX; //返回當事件被觸發時鼠標指針向對于瀏覽器頁面(或客戶區)的水平坐標。 let volX = vol.getBoundingClientRect().x; //getBoundingClientRect()獲取元素的寬高位置 let disX = x - volX; disX = Math.max(0, disX); //返回最大數字 disX = Math.min(120, disX); //返回最小數字 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代碼

這里我使用了{}作用域,讓let 或 const聲明的變量只在 let 或 const命令所在的代碼塊 {} 內有效,在 {} 之外不能訪問(ECMAScript 6(簡稱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='http://www.b3g6.com/bcjs/images/暫停.png' alt=''/>’; } else { music.pause(); event.currentTarget.innerHTML = ’<img src='http://www.b3g6.com/bcjs/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 () { //自動播放下一首 index++; if (index > songs.length - 1) { index = 0; } changeMusic(index); }) music.addEventListener('loadedmetadata', function(event) { //提示音頻的元數據已加載 tTime.innerHTML = parseInt(music.duration / 60) + ':' + parseInt(music.duration % 60); }); music.addEventListener('timeupdate', function(event) { //監聽音樂事實播放事件 let jd = music.currentTime / music.duration; //music.duration總時長 music.currentTime 當前時長 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()解析一個字符串,并返回一個整數 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; //返回當事件被觸發時鼠標指針向對于瀏覽器頁面(或客戶區)的水平坐標。 let volX = vol.getBoundingClientRect().x; //getBoundingClientRect()獲取元素的寬高位置 let disX = x - volX; disX = Math.max(0, disX); //返回最大數字 disX = Math.min(120, disX); //返回最小數字 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實現音樂播放器

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

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
丝袜亚洲另类欧美| 人人精品人人爱| 麻豆精品网站| 在线亚洲国产精品网站| 欧美高清不卡| 精品一区三区| 久久亚洲色图| 日韩精品高清不卡| 国产精品色婷婷在线观看| 国产精品美女午夜爽爽| 麻豆国产91在线播放| 国产成人精品一区二区三区在线| 精品国产18久久久久久二百| 日本精品影院| 男人的天堂亚洲一区| 国产一区导航| 日本精品一区二区三区在线观看视频| 国产毛片一区二区三区| av中文资源在线资源免费观看| 久久精品中文| 综合激情网...| www.51av欧美视频| 蜜桃久久精品一区二区| 麻豆精品久久久| 首页亚洲欧美制服丝腿| 国产精品亚洲综合在线观看| 日韩欧美一区二区三区免费观看| aa亚洲婷婷| 国产一区二区三区亚洲综合| 免费一级片91| 久久一区欧美| 亚洲伊人精品酒店| www在线观看黄色| 色综合视频一区二区三区日韩| 色爱综合网欧美| 在线看片一区| 欧美aa国产视频| 成人黄色av| 国产精品久久久久久久久久久久久久久 | 亚洲尤物av| 欧美日韩精品免费观看视欧美高清免费大片 | 国产精品毛片视频| 在线视频亚洲| 日韩精品欧美| 免费在线成人| 97精品国产99久久久久久免费| 91久久国产| 国产精品sss在线观看av| 水野朝阳av一区二区三区| 日韩国产在线| 国产白浆在线免费观看| 精品一区不卡| 国产极品嫩模在线观看91精品| 亚洲精品极品| 中文字幕成人| 日韩中文一区二区| 午夜久久av | 国语对白精品一区二区| 久久国产三级| 国产日韩中文在线中文字幕| 五月国产精品| 亚洲精品第一| 日韩一区中文| 欧美天堂在线| 精品亚洲成人| av资源新版天堂在线| 中文字幕在线官网| 婷婷成人在线| 亚洲一区国产| 91麻豆精品激情在线观看最新| 日韩激情综合| 国产欧美69| 国产一区二区三区久久久久久久久| 老色鬼精品视频在线观看播放| 麻豆91在线播放| 久久婷婷亚洲| 一区二区国产在线| 香蕉久久久久久| 精品三级在线| 999久久久免费精品国产| 99国产精品久久久久久久| 日本一区中文字幕| 精品国产亚洲一区二区三区大结局| 国产精品黑丝在线播放| 不卡一区综合视频| 日韩高清欧美激情| 国产 日韩 欧美 综合 一区| 婷婷成人在线| 美女久久久久久| 视频一区欧美精品| 精品免费在线| 亚洲一区二区三区久久久| 国产成人77亚洲精品www| 亚洲一区二区三区高清| 精品一区二区三区亚洲| 久久不射中文字幕| 亚洲精品**中文毛片| 亚洲综合专区| 久久青草久久| 麻豆精品久久久| 日本欧洲一区二区| 国产高清不卡| 香蕉久久国产| 久久久久网站| 国语精品一区| 天堂va在线高清一区| 久久国产亚洲| 麻豆一区二区三| 日韩国产欧美一区二区三区| 黑丝一区二区三区| 久久一区二区中文字幕| 国产福利91精品一区二区| 日韩一区二区三区免费视频| 欧美 日韩 国产精品免费观看| 精品视频自拍| 国产精品www994| 国产欧美日韩免费观看| 日韩一级不卡| 99精品在线| 神马午夜在线视频| 成人在线免费观看91| 免费在线成人| 国产精品久久久久久久久免费高清| 三级在线观看一区二区| 亚洲精品91| 欧美日韩黑人| 久久国产毛片| 亚洲二区在线| 伊人精品一区| 午夜精品网站| 亚洲在线一区| 玖玖玖国产精品| 欧美freesex黑人又粗又大| 激情综合五月| 福利在线免费视频| 中文字幕在线视频网站| 日韩欧美精品综合| 久久久久久美女精品| 午夜久久黄色| 日韩激情中文字幕| 精品中文字幕一区二区三区四区| 麻豆中文一区二区| 91视频一区| 婷婷综合网站| 亚洲区国产区| 欧美极品中文字幕| 91一区二区三区四区| 久久国产麻豆精品| 国产精品一区二区精品| 日韩免费小视频| 亚洲影视一区二区三区| 国产欧美一区| 欧美aa在线观看| 在线精品一区| 三上亚洲一区二区| 视频一区在线播放| 国产精品sss在线观看av| 亲子伦视频一区二区三区| 免费中文字幕日韩欧美| 麻豆精品在线观看| 国产亚洲激情| 成人影视亚洲图片在线| 日韩精品1区| 日本欧美韩国一区三区| 久久久国产亚洲精品| 91精品国产经典在线观看| 麻豆精品蜜桃| 婷婷视频一区二区三区| 久久精品国产www456c0m| 久久99精品久久久久久园产越南| 国产一区二区三区自拍| 国产精品chinese| 免费视频最近日韩| 日韩和的一区二在线| 国产免费av国片精品草莓男男| 国产亚洲高清视频| 日韩av福利| 日韩一区二区三区精品 | 国产美女久久| 综合欧美精品| 黄色日韩在线| 欧美日韩在线网站| jizzjizz中国精品麻豆| 欧美亚洲三级| 日韩精品一级中文字幕精品视频免费观看| 色欧美自拍视频| 九九99久久精品在免费线bt| 欧美一区影院| 国产亚洲精aa在线看| 国产欧美日韩视频在线| 91亚洲无吗| 亚洲精品电影| 野花国产精品入口| 国产视频一区三区| 免费精品视频最新在线| 蜜桃视频一区二区| 欧美亚洲福利| 精品美女久久| 日韩中文影院| 伊人久久亚洲热|