Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537
多站點都會使用到視頻. HTML5 提供了展示視頻的標準。
檢測您的瀏覽器是否支持 HTML5 視頻:
檢測
Web站點上的視頻
直到現在,仍然不存在一項旨在網頁上顯示視頻的標準。
今天,大多數視頻是通過插件(比如 Flash)來顯示的。然而,并非所有瀏覽器都擁有同樣的插件。
HTML5 規定了一種通過 video 元素來包含視頻的標準方法。
瀏覽器支持
Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 支持 <video> 元素.
注意: Internet Explorer 8 或者更早的IE版本不支持 <video> 元素。
HTML5 (視頻)- 如何工作
如需在 HTML5 中顯示視頻,您所有需要的是:
實例
<video width="320" height="240" controls>
<source src="movie.mp4" type="video/mp4">
<source src="movie.ogg" type="video/ogg">
您的瀏覽器不支持Video標簽。
</video>
<video> 元素提供了 播放、暫停和音量控件來控制視頻。
同時<video> 元素元素也提供了 width 和 height 屬性控制視頻的尺寸.如果設置的高度和寬度,所需的視頻空間會在頁面加載時保留。。如果沒有設置這些屬性,瀏覽器不知道大小的視頻,瀏覽器就不能再加載時保留特定的空間,頁面就會根據原始視頻的大小而改變。
<video> 與</video> 標簽之間插入的內容是提供給不支持 video 元素的瀏覽器顯示的。
<video> 元素支持多個 <source> 元素. <source> 元素可以鏈接不同的視頻文件。瀏覽器將使用第一個可識別的格式:
視頻格式與瀏覽器的支持
當前, <video> 元素支持三種視頻格式: MP4, WebM, 和 Ogg:
瀏覽器 | MP4 | WebM | Ogg |
---|---|---|---|
Internet Explorer | YES | NO | NO |
Chrome | YES | YES | YES |
Firefox | YES | YES | YES |
Safari | YES | NO | NO |
Opera | YES (從 Opera 25 起) | YES | YES |
MP4 = 帶有 H.264 視頻編碼和 AAC 音頻編碼的 MPEG 4 文件
WebM = 帶有 VP8 視頻編碼和 Vorbis 音頻編碼的 WebM 文件
Ogg = 帶有 Theora 視頻編碼和 Vorbis 音頻編碼的 Ogg 文件
視頻格式
格式 | MIME-type |
---|---|
MP4 | video/mp4 |
WebM | video/webm |
Ogg | video/ogg |
HTML5 <video> - 使用 DOM 進行控制
HTML5 <video> 和 <audio> 元素同樣擁有方法、屬性和事件。
<video> 和 <audio>元素的方法、屬性和事件可以使用JavaScript進行控制.
其中的方法有用于播放、暫停以及加載等。其中的屬性(比如時長、音量等)可以被讀取或設置。其中的 DOM 事件能夠通知您,比方說,<video> 元素開始播放、已暫停,已停止,等等。
例中簡單的方法,向我們演示了如何使用 <video> 元素,讀取并設置屬性,以及如何調用方法。
實例 1
為視頻創建簡單的播放/暫停以及調整尺寸控件:
播放/暫停 放大 縮小 普通
上面的例子調用了兩個方法:play() 和 pause()。它同時使用了兩個屬性:paused 和 width。
HTML5 Video 標簽
標簽 | 描述 |
---|---|
<video> | 定義一個視頻 |
<source> | 定義多種媒體資源,比如 <video> 和<audio> |
<track> | 定義在媒體播放器文本軌跡 |
Video.js是一個基于HTML5世界而構建的網絡視頻播放器。它支持HTML5和Flash視頻,還可以通過插件支持全球最受歡迎的視頻網站。它支持桌面和移動設備上的視頻播放。該項目于2010年中期啟動,現在該播放器已用于超過400,000個網站,可見其受歡迎程度,所以它可能真的是你一直在尋找的Web端的視頻播放器!在Github上也有了超過20k+的star數!
https://github.com/videojs/video.js
你可以有很多種方法來使用,不管是使用cdn還是下載下來靜態資源文件,亦或者是使用npm安裝都可以獲取它:
<link href="./video-js.min.css" rel="stylesheet"> <script src="./video.min.js"></script>
npm install video.js
接下來,使用Video.js就像創建<video>元素一樣簡單,但具有額外的數據設置屬性。也就是一個配置對象,以下代碼是一個最簡單的示例:
<video id="my-player" class="video-js" controls preload="auto" poster="封面url,設置就可以顯示封面" data-setup='{}'> <source src="視頻URL" type="video/mp4"> </source> </video>
當頁面加載時,Video.js將找到此元素并自動在其位置設置播放器。如果你不想使用自動設置,可以不使用data-setup屬性并使用videojs函數手動初始化<video>元素:
var player = videojs('my-player');
相關回調函數
var options = {}; var player = videojs('my-player', options, function onPlayerReady() { videojs.log('Your player is ready!'); this.play(); this.on('ended', function() { videojs.log('Awww...over so soon?!'); }); });
Video.js的文檔相當的詳細,本文篇幅不宜過長,如果你已經對它感興趣,那么你就可以對照文檔準備學習下了,由于其功能很強悍,那么相對應的文檔也就非常的詳細,分為詳細的API文檔和學習指南,通過閱讀文檔來實現你想要的功能(下面是一個簡單的截圖,使用了瀏覽器自帶的翻譯功能,很容易也能看懂):
官網也提供了一些比較高級的用法的demo,下面是一個帶播放列表的示例(此示例不足以體現他的強大):
可切換視頻
畫中畫
豐富的菜單按鈕工具(包括音頻、多語言等設置),支持中文語言包
除了以上demo所展示的,還包括自定義皮膚、React中使用、插件等功能,可以說是非常的豐富了,要比自帶的Video標簽功能豐富了無數倍,有視頻網站開發的朋友可以嘗試使用它,我相信它一定對你有所幫助!
插件千千萬,好用的卻不多,特別是相對復雜的,要么收費,要么功能不夠強大,但是有很多開發者貢獻了開源的項目供開發者使用才造就了如今技術的蓬勃發展,Video.js只是其中一個,本文只是提出來這樣一個必須贊一個的插件,其詳細的內容遠不止于此,感興趣的話可以閱讀相關文檔學習,如果你有更好的建議,也可以在評論區留言分享,希望對你有所幫助!
者:semlinker
轉發鏈接:https://mp.weixin.qq.com/s/tgiHiint3iTfPnr318kuFg
*請認真填寫需求信息,我們會在24小時內與您取得聯系。