十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
這篇文章將為大家詳細(xì)講解有關(guān)HTML5中video標(biāo)簽如何實(shí)現(xiàn)播放控制,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
html5標(biāo)簽video(播放器)初始化需要做的一些工作,如何簡(jiǎn)單快速使用html5的播放器,本文將重點(diǎn)介紹如何用JS來(lái)操作video標(biāo)簽,也就是如何對(duì)video做一些簡(jiǎn)單基本的操作,包括了播放器的播放、暫停,音量的讀取、設(shè)置等寫(xiě)相關(guān)操作,從而開(kāi)始播放器的擴(kuò)展之路。
本文的目錄:
1.獲取影片總時(shí)長(zhǎng)
2.播放、暫停
3.獲取影片已播放時(shí)間和設(shè)置播放點(diǎn)
4.音量的獲取和設(shè)置
第一、獲取影片總時(shí)長(zhǎng)
對(duì)播放器(video)操作,首先要得到的是影片的一些信息,其中一個(gè)就是總時(shí)長(zhǎng),除了內(nèi)容以為,總時(shí)長(zhǎng)也是第一時(shí)間要顯示的。在對(duì)video進(jìn)行操作的的前先給video標(biāo)簽添加一個(gè)ID,這樣方便我們獲取video元素
設(shè)置一個(gè)ID后,那么就可以開(kāi)始操作了,要獲取總時(shí)長(zhǎng),要用到video的一個(gè)事件-loadedmetadata,這個(gè)事件的觸發(fā)表示元數(shù)據(jù)(媒體的一些基本信息)已經(jīng)加載完成,用addEventListener監(jiān)聽(tīng)事件
var myVideo = document.getElementById('myVideo');//獲取video元素 myVideo.addEventListener("loadedmetadata", function(){ //要執(zhí)行的代碼 }); 好了,已經(jīng)監(jiān)聽(tīng)了,那么接下來(lái)要做的就是獲取總時(shí)長(zhǎng),其實(shí)就是一個(gè)屬性-duration var myVideo = document.getElementById('myVideo')//獲取video元素 ,tol = 0 ; myVideo.addEventListener("loadedmetadata", function(){ tol = myVideo.duration;//獲取總時(shí)長(zhǎng) });
需要注意的是獲取到的在總時(shí)長(zhǎng)的單位為秒,顯示的時(shí)候根據(jù)需要去轉(zhuǎn)換。
第二、播放、暫停
對(duì)播放器來(lái)說(shuō)最基本的一個(gè)功能就是播放和暫停了,而在獲取總時(shí)長(zhǎng)后,接著的操作也就是播放和暫停。這個(gè)時(shí)候用到了video的兩個(gè)方法就是play和pause
var myVideo = document.getElementById('myVideo')//獲取video元素 ,tol = 0 ; myVideo.addEventListener("loadedmetadata", function(){ tol = myVideo.duration;//獲取總時(shí)長(zhǎng) });//播放 function play(){ myVideo.play(); }
//暫停 function pause(){ myVideo.pause(); }
需要注意的是,當(dāng)播放結(jié)束后再運(yùn)行play方法將會(huì)從頭播放。
第三、獲取影片的播放時(shí)間和設(shè)置播放點(diǎn)
播放器能播放和暫停后,那么接下來(lái)需要看到的就是影片播放了多久,播放到哪個(gè)時(shí)間點(diǎn)了。這個(gè)操作跟獲取總時(shí)長(zhǎng)很相似,都是需要監(jiān)聽(tīng)一個(gè)事件和獲取一個(gè)屬性的值,那么用到的是video的timeupdate事件和currentTime屬性
//播放時(shí)間點(diǎn)更新時(shí) myVideo.addEventListener("timeupdate", function(){ var currentTime = myVideo.currentTime;//獲取當(dāng)前播放時(shí)間 console.log(currentTime);//在調(diào)試器中打印 });
運(yùn)行后會(huì)在控制臺(tái)看到很多數(shù)據(jù)...
我們經(jīng)常會(huì)接到一個(gè)要求,那就是上次看到了10分鐘了,這次看要從第十分鐘開(kāi)始看,那么這個(gè)時(shí)候就需要設(shè)置播放點(diǎn)了,設(shè)置播放點(diǎn)用得還是currentTime屬性,currentTime屬性是可讀寫(xiě)的,要注意的是設(shè)置值的單位是秒,如果播放點(diǎn)不是秒為單位那就要進(jìn)行轉(zhuǎn)換
//設(shè)置播放點(diǎn) function playBySeconds(num){ myVideo.currentTime = num; }
第四、音量的獲取和設(shè)置
播放器播放的過(guò)程中能暫停、播放,知道現(xiàn)在播放到哪里了和可以從某個(gè)時(shí)間點(diǎn)開(kāi)始播放,那么接下來(lái)操作的就是音量了。這一點(diǎn)跟第三相似,獲取音量可以直接用volume屬性就可以了,但是在這里還要介紹的是音量改變的觸發(fā)事件,方面以后需要自定義UI使用,那就是volumechange事件
//音量改變時(shí) myVideo.addEventListener("volumechange", function(){ var volume = myVideo.volume;//獲取當(dāng)前音量 console.log(volume);//在調(diào)試器中打印 });
當(dāng)你通過(guò)控制條來(lái)改變音量時(shí),你會(huì)看到調(diào)試?yán)锩嬗泻芏鄶?shù)據(jù)。要注意的是音量的范圍值為0~1,一般在UI中都是用百分比,所以需要的時(shí)候要進(jìn)行轉(zhuǎn)換。
音量是可以通過(guò)改變屬性來(lái)設(shè)置的,跟播放的時(shí)間點(diǎn)是相似的,只不過(guò)音量設(shè)置的是volume屬性
//設(shè)置音量 function setVol(num){ myVideo.volume = num; }
下面是完整的代碼:
Video step2
總結(jié):通過(guò)這四個(gè)步驟來(lái)了解html5標(biāo)簽video(播放器)的基本操作,而這些操作主要是通過(guò)JS來(lái)監(jiān)聽(tīng)video的事件和對(duì)video屬性的讀寫(xiě)來(lái)完成的,熟悉這四點(diǎn)即可靈活的在使用播放器,再根據(jù)應(yīng)用場(chǎng)景來(lái)調(diào)整即可。
關(guān)于HTML5中video標(biāo)簽如何實(shí)現(xiàn)播放控制就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。