HTML 5 video 視頻標籤全屬性詳解

來源:互聯網
上載者:User

標籤:type屬性   通過   判斷   controls   表示   audio   dex   firefox      

現在如果要在頁面中使用video標籤,需要考慮三種情況,支援Ogg Theora或者VP8(如果這玩意兒沒出事的話)的(Opera、Mozilla、Chrome),支援H.264的(Safari、IE 9、Chrome),都不支援的(IE6、7、8)。好吧,現在讓我們從技術層面來認識HTML 5的視頻,包括video標籤的使用,視頻對象可以用到的媒介屬性和方法,以及媒介事件。

Video標籤的使用

Video標籤含有src、poster、preload、autoplay、loop、controls、width、height等幾個屬性, 以及一個內部使用的標籤<source>。Video標籤內除了可以包含<source>標籤外,還可以包含當指定的視頻都不能 播放時,返回的內容。

(1) src屬性和poster屬性

你能想象src屬性是用來幹啥的。跟<img>標籤的一樣,這個屬性用於指定視頻的地址。而poster屬性用於指定一張圖片,在當前視頻資料無效時顯示(預覽圖)。視頻資料無效可能是視頻正在載入,可能是視頻地址錯誤等等。

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay"></video>

 

(2) preload屬性

這個屬性也能通過名字瞭解用處,此屬性用於定義視頻是否預先載入。屬性有三個可選擇的值:none、metadata、auto。如果不使用此屬性,預設為auto。

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none"></video>

 

None:不進行預先載入。使用此屬性值,可能是頁面製作者認為使用者不期望此視頻,或者減少HTTP請求。

Metadata:部分預先載入。使用此屬性值,代表頁面製作者認為使用者不期望此視頻,但為使用者提供一些中繼資料(包括尺寸,第一幀,曲目列表,期間等等)。

Auto:全部預先載入。

(3) autoplay屬性

又是一個看名字知道用處的屬性。Autoplay屬性用於設定視頻是否自動播放,是一個布爾屬性。當出現時,表示自動播放,去掉是表示不自動播放。

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none"></video>

 

注意,HTML中布爾屬性的值不是true和false。正確的用法是,在標籤中使用此屬性工作表示true,此時屬性要麼沒有值,要麼其值恒等於他的名字 (此處,自動播放為<video autoplay />或者<video autoplay=”autoplay” />);而在標籤中不使用此屬性工作表示false(此處不進行自動播放為<video />)。

 (4) loop屬性

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" loop="loop"></video>

 

一目瞭然,loop屬性用於指定視頻是否迴圈播放,同樣是一個布爾屬性。

(5) controls屬性

<video width="658" height="444" src="http://www.youname.com/images/first.mp4" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"></video>

 

Controls屬性用於向瀏覽器指明頁面製作者沒有使用指令碼產生播放控制器,需要瀏覽器啟用本身的播放控制欄。

控制欄須包括播放暫停控制,播放進度控制,音量控制等等。

每個瀏覽器預設的播放控制欄在介面上不一樣。由於我瀏覽器的詭異問題,Firefox和Safari的Video標籤不正常,所以這兩個只能在網上找了。

(6) width屬性和height屬性

屬於標籤的通用屬性了,這個不用多說。

(7) source標籤

<video width="658" height="444" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"><source src="http://www.youname.com/images/first.ogv" /><source src="http://www.youname.com/images/first.ogg" /></video>

 

Source標籤用於給媒體(因為audio標籤同樣可以包含此標籤,所以這兒用媒體,而不是視頻)指定多個可選擇的(瀏覽器最終只能選一個)檔案地址,且只能在媒體標籤沒有使用src屬性時使用。

瀏覽器按source標籤的順序檢測標籤指定的視頻是否能夠播放(可能是視頻格式不支援,視頻不存在等等),如果不能播放,換下一個。此方法多用於相容不同的瀏覽器。Source標籤本身不代表任何含義,不能單獨出現。

此標籤包含src、type、media三個屬性。

src屬性:用於指定媒體的地址,和video標籤的一樣。

Type屬性:用於說明src屬性指定媒體的類型,協助瀏覽器在擷取媒體前判斷是否支援此類別的媒體格式。

Media屬性:用於說明媒體在何種媒介中使用,不設定時預設值為all,表示支援所有媒介。你想到<style>標籤的media屬性了嗎?一樣一樣一樣的。

(8) 一個完整的例子

<video width="658" height="444" poster="http://www.youname.com/images/first.png" autoplay="autoplay" preload="none" controls="controls"><source src="http://www.youname.com/images/first.ogv" /><source src="http://www.youname.com/images/first.ogg" /></video>

 

這段代碼在頁面中定義了一個視頻,此視頻的預覽圖為poster的屬性值,顯示瀏覽器的預設媒體控制欄,預先載入視頻的中繼資料,迴圈播放,寬度為900像素,高度為240像素。

第一選擇視頻地址為第一個source標籤的src屬性值,視頻類別為Ogg視頻,視頻編碼解碼器為Theora,音頻編碼解碼器為Vorbis,播放媒 介為顯示器;第二選擇視頻地址不再累述。如果你還要相容IE的話,可以在最後一個source標籤後再加上Flash播放器的標籤集,或者使用一點 JavaScript代碼。

HTML 5 video 視頻標籤全屬性詳解

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.