用 標籤打造一個屬於本身的HTML5音樂播放器

上一章節,咱們剛剛講了<video>標籤,今晚,咱們講的是<audio>標籤,這兩個東東除了表示的內容不同之外,其餘的特性類似的地方真的太多了,屬性和用法幾乎同樣,也就說,若是上一章節你理解了,那麼這一節你學起來會:毫無壓力。chrome

 

<audio>簡介瀏覽器

 

<audio>標籤:用於在文檔中表示音頻內容。利用它,你能夠在你的我的網站上放一首你喜歡的歌。ide

 


   <audio src="music.mp3"></audio>

 

用法很簡單,跟<video>標籤同樣,屬性src指定音頻文件地址。oop

 

若是你僅僅這樣寫,頁面上不會看到有明顯的東西,<audio>標籤默認是隱藏的。學習

 

對於不支持<audio>標籤的瀏覽器,會把標籤的文本內容顯示出來。網站

 


   <audio src="music.mp3">
        別試了,是你的瀏覽器渣渣
   </audio>

 

( 你們都叫我:IE8 )spa

 

爲了方便咱們對音頻文件進行控制,操做它的進度、播放暫停、音量等等,咱們能夠給它添加controls屬性:firefox

 


   <audio src="m.mp3" controls></audio>

 

用法跟<video>標籤同樣。對於加上了controls屬性, 不一樣的瀏覽器會展現不一樣樣式的控制面板。視頻

 

 

( chrome瀏覽器的音頻控制面板 )對象

 

 

( firefox瀏覽器的音頻控制面板 )

 

 

( IE瀏覽器的音頻控制面板 )

 

哪一個好看就見仁見智了~~

 

 

跟<video>標籤同樣,<audio>標籤也有一個字標籤:<source>。

 

它們的做用和用法都同樣,就是用來引入多個音頻,瀏覽器會選擇一個支持的音頻格式進行加載,對於不支持<audio>標籤的瀏覽器,<source>元素也能夠做爲瀏覽器不識別的內容加入到文檔中。

 


   <audio>
        <source src="music.mp3">
        <source src="music.ogg">
        <source src="music.wav">
   </audio>

 

注:主流的音頻文件格式有:mp三、wav、ogg。不一樣的瀏覽器對三種格式支持程度不同。其中mp3格式支持度最好。

 

autoplay屬性:加載完成後,自動播放。也很是簡單、使用。


  <audio src="m.mp3" autoplay></audio>

 

loop屬性:顧名思義,循環播放。


   <audio src="m.mp3" loop></audio>

 

preload屬性:用來控制音頻在何時進行加載。


   <audio src="m.mp3" preload="auto"></audio>

 

對應的值有3種:

  • none:默認不加載,等有須要的時候再加載。

  • metadata:元數據,默認不加載,可是能夠提取該音頻的元數據信息。

  • auto:自動加載,網頁加載完就加載整個音頻。

 

muted屬性:靜音效果。


   <audio src="m.mp3" muted></audio>

 

加了muted屬性,音頻即便在播放的時候,也是沒有聲音,除非用戶手動調整控制面板的音量。

 

JavaScript控制音頻

 

JavaScript能夠經過video對象控制網頁視頻;一樣能夠audio對象操做網頁音頻。

 

首先咱們經過getElementById(ID)方法獲取到一個audio對象。假設id爲「music「。

 


   <audio id="music" src="m.mp3"></audio>

   let m = document.getElementById('music');

 

控制加載:


   m
.load();//加載

 

若是你的<audio>標籤是手動生成的節點,能夠用load方法來實現加載。

 

控制播放:


   m
.play();//播放

 

調用play( )方法能夠執行播放。

 

控制暫停:


   m
.pause();//暫停

 

調用pause( )方法能夠執行暫停播放。

 

指定播放時間:


   m
.fastSeek(20);

 

這樣的話,音頻會定位到20秒的播放位置。不過目前只有Firefox瀏覽器支持,你能夠經過currentTime屬性來實現。

 

獲取和設置已播放的時間


   m
.currentTime

 

經過currentTime屬性,你能夠拿到當前音頻播放了多久,返回的數字以( s )秒爲單位。

 


   m
.currentTime = 10;

 

你也能夠給它賦值,這樣,音頻會定位到10秒的播放位置。

 

是否自動播放:


   m
.autoplay = true;//自動播放

 

能夠直接在<audio>標籤上加上autoplay屬性,也能夠經過JavaScript來設置autoplay屬性。它是一個布爾值,true表明自動播放,false表明非自動播放

 

是否循環播放:


   m
.loop = true;//循環播放

 

能夠直接在<audio>標籤上加上loop屬性,也能夠經過JavaScript來設置loop屬性。它也是一個布爾值,true表明循環播放,false表明單曲播放

 

是否顯示控制面板:


   m
.controls = true;//顯示控制面板

 

能夠直接在<audio>標籤上加上controls屬性,也能夠經過JavaScript來設置controls屬性。它也是一個布爾值,true表明顯示控制面板,false表明隱藏控制面板。

 

是否靜音:


   m
.muted = true;//靜音

 

能夠直接在<audio>標籤上加上muted屬性,也能夠經過JavaScript來設置muted屬性。它也是一個布爾值,true表明靜音,false表明有聲音

 

是否暫停:


   m
.paused  //是否暫停

判斷音頻當前是否暫停,返回true表明暫停,返回false表明正在播放;默認是true;該值只能讀取,不能修改。

 

調用play( )方法後,m.paused的值會變成false;調用pause( )方法後,m.paused的值會變成true。

 

調節音量:


   m
.volume = 0.1;

 

音量的取值範圍在:0(無聲)~1(最大聲)之間。能夠對volume屬性賦合理的值或者作一些運算,來改變音頻的音量。

 

以上就是<audio>標籤很經常使用也很實用的一些屬性和方法了。只要掌握了這些知識點,你就能夠實現一個本身的音樂播放器。固然,<audio>標籤還有其餘屬性,我不在這裏展開, 學習的階段只要掌握以上這些就夠了,有興趣的同窗能夠自行去網上搜索

相關文章
相關標籤/搜索