摘要:我們給視頻添加一個獲取到元數據事件給播放按鈕圖片添加事件獲取到元數據果然出現了視頻的長度,可是這是按秒計算的啊。。。
回顧
1)H5打造屬于自己的視頻播放器(HTML篇)
2)H5打造屬于自己的視頻播放器(邏輯篇)
在HTML篇當中我們寫好了樣式,今天我們為video新增一個樣式
.bad-video video { width: 100%; height: 100%; display: block; object-fit:fill; }
高,寬,內容,都充父元素
乳此一來,我們的HMTL元素內容為
吹著口哨寫JS00:00/00:00全屏
幸好我們在寫JS之前,先整理好了邏輯思緒,并寫好了筆記H5打造屬于自己的視頻播放器(邏輯篇)
以下文章將要用到 號稱 最接近原生APP體驗的高性能前端框架 的 MUI
首先,讓我們來新建一個js文件,比如,bvd.js 并注冊一下全局的一個入口
(function($){ var bvd = function(dom) { this.dom = document.querySelector(dom || "video"); } var pro = bvd.prototype; pro.test = function(){ console.log(this.dom) } var nv = null; $.bvd = function(dom) { return nv || (nv = new bvd(dom)); } }(mui))
讓我們在video.html引入bvd.js 并且來測試一下吧!
看來是ok的,與此同時,為了html頁的簡潔美觀,我們將播放按鈕和控制條用JS動態生成
(function($){ var bvd = function(dom) { var that = this; $.ready(function(){ //獲取視頻元素 that.video = document.querySelector(dom || "video"); //獲取視頻父元素 that.vRoom = that.video.parentNode; //元素初始化 that.initEm(); }) } var pro = bvd.prototype; pro.initEm = function(){ //先添加播放按鈕 this.vimg = document.createElement("img"); this.vimg.src = "img/play.png"; this.vimg.className = "vplay"; this.vRoom.appendChild(this.vimg); } var nv = null; $.bvd = function(dom) { return nv || (nv = new bvd(dom)); } }(mui))
這里有個小細節,如果img的src設置為本地資源的話,那么以后使用會出現很多問題,比如,頁面層級發生變化時,你要去修改bvd.js,以免夜長夢多,我們將圖片轉為base64
再添加控制條
pro.initEm = function(){ //先添加播放按鈕 this.vimg = document.createElement("img"); this.vimg.src = ""; this.vimg.className = "vplay"; this.vRoom.appendChild(this.vimg); //添加控制條 this.vC = document.createElement("div"); this.vC.classList.add("controls"); this.vC.innerHTML = "00:00/00:00全屏"; this.vRoom.appendChild(this.vC); }
再把 video.html中的 播放按鈕 和 控制條 注釋,看看我們寫的代碼效果如何
大家可以看到,紅色是我們注釋的,綠色的是我們js生成的,奈斯
真正開始我們js篇的第一步啦
初始化事件,先寫個播放按鈕播放視頻事件測試一下
//元素初始化 that.initEm(); //事件初始化 that.initEvent(); ---------- pro.initEvent = function(){ var that = this; //給播放按鈕圖片添加事件 this.vimg.addEventListener("tap",function(){ that.video.play(); }) }
tap事件,是MUI封裝好的一個適合移動端點擊的事件哦,移動端click事件延遲300ms,建議大家多用tap,關于tap事件是如何模擬的,請看HTML5觸摸事件演化tap事件介紹
喲西,視頻開始播放拉?。?!
回顧一下H5打造屬于自己的視頻播放器(邏輯篇)
溫習一下移動端HTML5
1)封面 在這里我沒啥好圖,就不設置了,大家可以試試在video標簽加入屬性 poster="圖片地址"
2)獲取視頻長度,ok,我們給視頻添加一個"loadedmetadata"獲取到元數據事件,什么事元數據?
舉個栗子:一部電影30個G,名字叫《我將帶頭沖鋒》,視頻長300小時
大小,名稱,長度,等這些應該就算是元數據了。
我們給視頻添加一個獲取到元數據事件
pro.initEvent = function(){ var that = this; //給播放按鈕圖片添加事件 this.vimg.addEventListener("tap",function(){ this.style.display = "none"; that.video.play(); }) //獲取到元數據 this.video.addEventListener("loadedmetadata",function(){ that.vC.querySelector(".duration").innerHTML = this.duration; }); }
果然出現了視頻的長度,可是這是按秒計算的啊。。。
這時我們可以寫一個時間轉換的函數
function stom(t) { var m = Math.floor(t / 60); m < 10 && (m = "0" + m); return m + ":" + (t % 60 / 100).toFixed(2).slice(-2); }
轉換一下
可以,這很清真,今天我們暫時講到這,消化消息,也讓樓主整頓一下思緒
本章節JS1源碼放在這里
H5打造屬于自己的視頻播放器(JS篇2)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/11017.html
摘要:回顧打造屬于自己的視頻播放器篇在上一章節之中,已經把篇給大致樣式顯現了出來,接下來應該是篇了,可是在寫之前有必要先整理一下思緒,盲目亂寫是不對的,喝杯茶,撩撩妹,生活多美妙,寫起代碼來自然心情好思路正。 回顧 H5打造屬于自己的視頻播放器(HTML篇)在上一章節之中,已經把HTML篇給大致樣式顯現了出來,接下來應該是JS篇了,可是在寫之前有必要先整理一下思緒,盲目亂寫是不對的,喝杯茶,...
摘要:回顧打造屬于自己的視頻播放器篇在上一章節之中,已經把篇給大致樣式顯現了出來,接下來應該是篇了,可是在寫之前有必要先整理一下思緒,盲目亂寫是不對的,喝杯茶,撩撩妹,生活多美妙,寫起代碼來自然心情好思路正。 回顧 H5打造屬于自己的視頻播放器(HTML篇)在上一章節之中,已經把HTML篇給大致樣式顯現了出來,接下來應該是JS篇了,可是在寫之前有必要先整理一下思緒,盲目亂寫是不對的,喝杯茶,...
前言 眾所周知,16年無疑是直播行業的春天,同時也是H5的一次高潮。so,到現在用H5技術在移動端做網頁直播也是見怪不怪了,但是?。?!今天我們的主角是webApp下播放視頻參考文獻:1)HTML5+CSS3+JQuery打造自定義視頻播放器2)mui Html5 Video 實現方案3)移動端HTML5視頻播放優化實踐 搬好凳子看HTML 首先我們在HB下創建一個新的app項目,名稱為 欠債 sh...
前言 眾所周知,16年無疑是直播行業的春天,同時也是H5的一次高潮。so,到現在用H5技術在移動端做網頁直播也是見怪不怪了,但是?。。〗裉煳覀兊闹鹘鞘莣ebApp下播放視頻參考文獻:1)HTML5+CSS3+JQuery打造自定義視頻播放器2)mui Html5 Video 實現方案3)移動端HTML5視頻播放優化實踐 搬好凳子看HTML 首先我們在HB下創建一個新的app項目,名稱為 欠債 sh...
前言 眾所周知,16年無疑是直播行業的春天,同時也是H5的一次高潮。so,到現在用H5技術在移動端做網頁直播也是見怪不怪了,但是?。?!今天我們的主角是webApp下播放視頻參考文獻:1)HTML5+CSS3+JQuery打造自定義視頻播放器2)mui Html5 Video 實現方案3)移動端HTML5視頻播放優化實踐 搬好凳子看HTML 首先我們在HB下創建一個新的app項目,名稱為 欠債 sh...
閱讀 1855·2021-11-22 15:25
閱讀 3938·2021-11-17 09:33
閱讀 2519·2021-10-12 10:12
閱讀 1810·2021-10-09 09:44
閱讀 3240·2021-10-08 10:04
閱讀 1320·2021-09-29 09:35
閱讀 1956·2019-08-30 12:57
閱讀 1309·2019-08-29 16:22