HTML 音頻(Audio)
HTML?音頻(Audio)
聲音在HTML中可以以不同的方式播放.
問題以及解決方法
在 HTML 中播放音頻并不容易!
您需要諳熟大量技巧,以確保您的音頻文件在所有瀏覽器中(Internet Explorer, Chrome, Firefox, Safari, Opera)和所有硬件上(PC, Mac , iPad, iPhone)都能夠播放。
在本章,PHP中文網(wǎng)(php.cn) 為您總結(jié)了問題和解決方法。
使用插件
瀏覽器插件是一種擴展瀏覽器標準功能的小型計算機程序。
插件可以使用 <object> 標簽 或者 <embed> 標簽添加在頁面上.?
這些標簽定義資源(通常非 HTML 資源)的容器,根據(jù)類型,它們即會由瀏覽器顯示,也會由外部插件顯示。
使用 <embed> 元素
<embed>標簽定義外部(非 HTML)內(nèi)容的容器。(這是一個 HTML5 標簽,在 HTML4 中是非法的,但是所有瀏覽器中都有效)。
下面的代碼片段能夠顯示嵌入網(wǎng)頁中的 MP3 文件:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <embed height="50" width="100" src="horse.mp3"> <p>如果你無法聽到該音頻,那么可能你的電腦或瀏覽器不支持該文件格式。</p> <p>或者你沒有打開揚聲器。</p> </embed> </body> </html>
你在本地找一段mp3格式的音頻,將src="horse.mp3"換成你的mp3文件,再打開網(wǎng)頁試試看
問題:
<embed> 標簽在 HTML 4 中是無效的。頁面無法通過 HTML 4 驗證。
不同的瀏覽器對音頻格式的支持也不同。
如果瀏覽器不支持該文件格式,沒有插件的話就無法播放該音頻。
如果用戶的計算機未安裝插件,無法播放音頻。
如果把該文件轉(zhuǎn)換為其他格式,仍然無法在所有瀏覽器中播放。
使用 <object> 元素
<object tag> 標簽也可以定義外部(非 HTML)內(nèi)容的容器。
下面的代碼片段能夠顯示嵌入網(wǎng)頁中的 MP3 文件:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <object height="100" width="300" data="Kalimba.mp3"></object> <p>如果你無法聽到該音頻,那么可能你的電腦或瀏覽器不支持該文件格式。</p> <p>或者你沒有打開揚聲器。</p> </body> </html>
你在本地找一段mp3格式的音頻,將src="horse.mp3"換成你的mp3文件,再打開網(wǎng)頁試試看
問題:
不同的瀏覽器對音頻格式的支持也不同。
如果瀏覽器不支持該文件格式,沒有插件的話就無法播放該音頻。
如果用戶的計算機未安裝插件,無法播放音頻。
如果把該文件轉(zhuǎn)換為其他格式,仍然無法在所有瀏覽器中播放。
使用 HTML5 <audio> 元素
HTML5 <audio> 元素是一個 HTML5 元素,在 HTML 4 中是非法的,但在所有瀏覽器中都有效。
The <audio> element works in all modern browsers.
以下我們將使用 <audio> 標簽來描述 MP3 文件(Internet Explorer、Chrome 以及 Safari 中是有效的), 同樣添加了一個 OGG 類型文件(Firefox 和 Opera瀏覽器中有效).如果失敗,它會顯示一個錯誤文本信息:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <audio controls> <source src="horse.mp3" type="audio/mpeg"> <source src="horse.ogg" type="audio/ogg"> 您的瀏覽器不支持該音頻格式。 </audio> </body> </html>
如果你的瀏覽器不支持音頻格式將會輸出 “您的瀏覽器不支持該音頻格式”這段話,否則反之
問題:
<audio> 標簽在 HTML 4 中是無效的。您的頁面無法通過 HTML 4 驗證。
您必須把音頻文件轉(zhuǎn)換為不同的格式。
<audio> 元素在老式瀏覽器中不起作用。
最好的 HTML 解決方法
下面的例子使用了兩個不同的音頻格式。HTML5 <audio> 元素會嘗試以 mp3 或 ogg 來播放音頻。如果失敗,代碼將回退嘗試 <embed> 元素。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <audio controls> <source src="horse.mp3" type="audio/mpeg"> <source src="horse.ogg" type="audio/ogg"> <embed height="50" width="100" src="horse.mp3"> </audio> </body> </html>
將src換成你本地的音頻試試看
問題:
您必須把音頻轉(zhuǎn)換為不同的格式。
<embed> 元素無法回退來顯示錯誤消息。
雅虎媒體播放器 - 一個簡單的添加音頻到你網(wǎng)站上的方式
雅虎媒體播放器為您的用戶提供的是一個小型的播放按鈕,而不是完整的播放器。不過,當您點擊該按鈕,會彈出完整的播放器。
請注意,這個播放器始終停靠在窗框底部。只需點擊它,就可將其滑出。
使用雅虎播放器是免費的。如需使用它,您需要把這段 JavaScript 插入網(wǎng)頁底部:
雅虎播放器可以播放MP3以及其他各種格式。你只需添加一行代碼到你的頁面或 博客中就可以輕松地將您的HTML頁面制作成 專業(yè)的播放列表:
<script src="http://mediaplayer.yahoo.com/latest"></script>
實例?
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <p><a href="Kalimba.mp3">Play mp3</a></p> <script src="http://mediaplayer.yahoo.com/latest"></script> </body> </html>
找段音頻文件試試看
使用超鏈接
如果網(wǎng)頁包含指向媒體文件的超鏈接,大多數(shù)瀏覽器會使用"輔助應(yīng)用程序"來播放文件。
以下代碼片段顯示指向 mp3 文件的鏈接。如果用戶點擊該鏈接,瀏覽器會啟動"輔助應(yīng)用程序"來播放該文件:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> <h2>鏈接到一首歌</h2> <p><a href="nverq.mp3">點擊此處播放</a></p> </body> </html>
找段音頻文件試試看
內(nèi)聯(lián)的聲音說明
當您在網(wǎng)頁中包含聲音,或者作為網(wǎng)頁的組成部分時,它被稱為內(nèi)聯(lián)聲音。
如果您打算在 web 應(yīng)用程序中使用內(nèi)聯(lián)聲音,您需要意識到很多人都覺得內(nèi)聯(lián)聲音令人惱火。同時請注意,用戶可能已經(jīng)關(guān)閉了瀏覽器中的內(nèi)聯(lián)聲音選項。
我們最好的建議是只在用戶希望聽到內(nèi)聯(lián)聲音的地方包含它們。一個正面的例子是,在用戶需要聽到錄音并點擊某個鏈接時,會打開頁面然后播放錄音。
HTML 多媒體標簽
HTML5 新標簽
? ? ?標簽 | ? ? ?描述 |
? ??<embed> | 定義內(nèi)嵌對象。HTML4 中不贊成,HTML5 中允許。 |
? ??<object> | 定義內(nèi)嵌對象。 |
? ??<param> | 定義對象的參數(shù)。 |
? ??<audio> | 定義了聲音內(nèi)容 |
? ??<video> | 定義一個視頻或者影片 |
? ??<source> | 定義了media元素的多媒體資源(<video> 和 <audio>) |
? ? ? ? <track> | 規(guī)定media元素的字幕文件或其他包含文本的文件 (<video> 和<audio>) |