HTML5 -- 音樂(lè)播放器

此播放器已更新到 2.0 版本,可以前去我的 Github 查看更新內(nèi)容

這兩天寫(xiě)了一個(gè)在線音樂(lè)播放器,支持播放本地音樂(lè),并且可以調(diào)整音量,顯示進(jìn)度條。 下圖是效果


demo01.gif

當(dāng)然,你還可以 在線體驗(yàn),接下來(lái)我會(huì)針對(duì)本程序的一些疑難點(diǎn)進(jìn)行解析。如果你想查看源碼,你可以 點(diǎn)擊這里


1. 圖標(biāo)的使用

這里的圖標(biāo)取自 FontAwesome,這是一種字體圖標(biāo),所以它可以隨著字體顏色的改變而改變,它的大小也是由字體的大小決定的,也就是 font-size 。


2. Progress 默認(rèn)樣式的改變

其實(shí)不難看出,程序中對(duì)進(jìn)度條的顏色進(jìn)行了設(shè)置,顏色的合理使用可以改變用戶體驗(yàn),所以我認(rèn)為這還是很有必要的。關(guān)于這一點(diǎn),有興趣的人可以去看 HTML5 progress元素的樣式控制、兼容與實(shí)例。

主要是下面兩段代碼,上面一段是適配 Google ChromeSafari, 下面則是為了適配 Firefox 。

progress::-webkit-progress-value {
    background: #6cf;
}

progress::-moz-progress-bar {
    background: #6cf;
}

3. 音樂(lè)信息的獲取

首先,我們需要在 JS 中取得 audio

var player = document.getElementById("player");

然后我們可以調(diào)用 player.duration 獲取音頻的總時(shí)長(zhǎng)(s), player.currentTime 可以取得當(dāng)前已經(jīng)播放的時(shí)長(zhǎng),我們可以利用這個(gè)這個(gè)屬性與總時(shí)長(zhǎng)的比值更新進(jìn)度條。player.volume 可以取得音頻播放時(shí)的音量,取值在 0.0 - 1.0 之間。


4. 設(shè)置間歇調(diào)用

為了更新進(jìn)度條,我設(shè)置了間歇調(diào)用,具體語(yǔ)句如下。

var interval = setInterval(change, 1000);

也就是說(shuō),每隔 1s 調(diào)用 change 這個(gè)函數(shù),下面來(lái)解釋 change 函數(shù)。

function change() {
    setCurrentTime();
    var currentTime = player.currentTime,
        duration = player.duration;

    var progress = (currentTime / duration).toFixed(2) * 100;
    progressElement.value = progress;
}

首先,調(diào)用 setCurrentTime() , 這個(gè)函數(shù)用于更新當(dāng)前播放時(shí)間。 progress 變量用于計(jì)算進(jìn)度條的值,注意將比值的結(jié)果轉(zhuǎn)換成兩位數(shù),然后轉(zhuǎn)換成百分制。


5. 監(jiān)聽(tīng)音頻播放完畢事件

當(dāng)音頻播放完畢后,會(huì)觸發(fā) ended 事件,我們要監(jiān)聽(tīng)這一事件進(jìn)行善后處理,具體要做那些事情呢?

  • 清除間歇調(diào)用
  • 清空進(jìn)度條
  • 清除音頻已播放時(shí)間,并將其置為 0:00
  • 改變播放按鈕的圖標(biāo)

如果有興趣的話,完全可以在音頻播放完畢后設(shè)置 loop 屬性,重新再播放一遍。


6. 上傳音樂(lè)

目前,這個(gè)程序也只能播放本地音樂(lè),那么要怎么選中本地音樂(lè)并且播放呢?

首先,你可能會(huì)想到用 input, 但那 UI 也太丑了吧? 所以,我們需要做一些改變,我們?nèi)匀皇褂?input 控件,但是我們將其 display 設(shè)置為 none, 然后我們?cè)俣x一個(gè)標(biāo)簽,并且監(jiān)聽(tīng)其點(diǎn)擊事件,如果事件觸發(fā),那么我們就手動(dòng)觸發(fā) input 控件的點(diǎn)擊事件。具體操作如下所示。

  • input 控件
<input type="file" id="file">

#file {
display: none;
}
  • 自選標(biāo)簽
<span id="add-music"><i class="fa fa-upload" aria-hidden="true"></i></span>

var addMusicElement = document.getElementById("add-music"),
     fileElement = document.getElementById("file");

addMusicElement.addEventListener("click", function(event) {
    fileElement.click();
});

當(dāng)然,想播放本地音樂(lè),我們選中文件之后還需要做一些轉(zhuǎn)變,否則是無(wú)法播放的,具體代碼如下所示。

function getURL() {
    var file = fileElement.files[0];
    var url = URL.createObjectURL(file);
    player.src = url;
}

通過(guò)第二句轉(zhuǎn)換而得的 URL, 就可以賦值給 audio 進(jìn)行播放了。


7. 小技巧

關(guān)于播放時(shí)間,由于想要顯示 0:00 格式,所以可能需要一些小技巧,比如下面這樣。

second = (second >= 10) ? second : '0' + second;

End!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容