HTML5video標(biāo)簽播放控制的技巧有哪些

這篇文章主要介紹“HTML5 video標(biāo)簽播放控制的技巧有哪些”的相關(guān)知識(shí),小編通過(guò)實(shí)際案例向大家展示操作過(guò)程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“HTML5 video標(biāo)簽播放控制的技巧有哪些”文章能幫助大家解決問(wèn)題。

為錯(cuò)那等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及錯(cuò)那網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、錯(cuò)那網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

第一、獲取影片總時(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元素

復(fù)制代碼

代碼如下:

<video id="myVideo" controls preload="auto" width=300 height="165"

poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg"

src="http://www.w3cschool.cc/try/demo_source/mov_bbb.mp4">

</video>

設(shè)置一個(gè)ID后,那么就可以開始操作了,要獲取總時(shí)長(zhǎng),要用到video的一個(gè)事件-loadedmetadata,這個(gè)事件的觸發(fā)表示元數(shù)據(jù)(媒體的一些基本信息)已經(jīng)加載完成,用addEventListener監(jiān)聽事件

復(fù)制代碼

代碼如下:

var myVideo = document.getElementById('myVideo');//獲取video元素

myVideo.addEventListener("loadedmetadata", function(){

//要執(zhí)行的代碼

});

好了,已經(jīng)監(jiān)聽了,那么接下來(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

復(fù)制代碼

代碼如下:

var myVideo = document.getElementById('myVideo')//獲取video元素

,tol = 0

;

myVideo.addEventListener("loadedmetadata", function(){

tol = myVideo.duration;//獲取總時(shí)長(zhǎng)

});</p><p> //播放

function play(){

myVideo.play();

}</p><p> //暫停

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)聽一個(gè)事件和獲取一個(gè)屬性的值,那么用到的是video的timeupdate事件和currentTime屬性

復(fù)制代碼

代碼如下:

//播放時(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分鐘了,這次看要從第十分鐘開始看,那么這個(gè)時(shí)候就需要設(shè)置播放點(diǎn)了,設(shè)置播放點(diǎn)用得還是currentTime屬性,currentTime屬性是可讀寫的,要注意的是設(shè)置值的單位是秒,如果播放點(diǎn)不是秒為單位那就要進(jìn)行轉(zhuǎn)換

復(fù)制代碼

代碼如下:

//設(shè)置播放點(diǎn)

function playBySeconds(num){

myVideo.currentTime = num;

}

    第四、音量的獲取和設(shè)置

    播放器播放的過(guò)程中能暫停、播放,知道現(xiàn)在播放到哪里了和可以從某個(gè)時(shí)間點(diǎn)開始播放,那么接下來(lái)操作的就是音量了。這一點(diǎn)跟第三相似,獲取音量可以直接用volume屬性就可以了,但是在這里還要介紹的是音量改變的觸發(fā)事件,方面以后需要自定義UI使用,那就是volumechange事件

復(fù)制代碼

代碼如下:

//音量改變時(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屬性

復(fù)制代碼

代碼如下:

//設(shè)置音量

function setVol(num){

myVideo.volume = num;

}

    下面是完整的代碼:

復(fù)制代碼

代碼如下:

<!DOCTYPE html>

<html>

<head>

<title>Video step2</title>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>

</head>

<body>

<video id="myVideo" controls preload="auto" width=300 height="165"

poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg"

src="http://www.w3cschool.cc/try/demo_source/mov_bbb.mp4">

</video>

<script>

var myVideo = document.getElementById('myVideo')//獲取video元素

,tol = 0 //總時(shí)長(zhǎng)

;

myVideo.addEventListener("loadedmetadata", function(){

tol = myVideo.duration;//獲取總時(shí)長(zhǎng)

});</p><p>//播放

function play(){

myVideo.play();

}</p><p>//暫停

function pause(){

myVideo.pause();

}</p><p>//播放時(shí)間點(diǎn)更新時(shí)

myVideo.addEventListener("timeupdate", function(){

var currentTime = myVideo.currentTime;//獲取當(dāng)前播放時(shí)間

console.log(currentTime);//在調(diào)試器中打印

});</p><p>//設(shè)置播放點(diǎn)

function playBySeconds(num){

myVideo.currentTime = num;

}</p><p>//音量改變時(shí)

myVideo.addEventListener("volumechange", function(){

var volume = myVideo.volume;//獲取當(dāng)前音量

console.log(volume);//在調(diào)試器中打印

});</p><p>//設(shè)置音量

function setVol(num){

myVideo.volume = num;

}

</script>

</body>

</html>

    總結(jié):通過(guò)這四個(gè)步驟來(lái)了解html5標(biāo)簽video(播放器)的基本操作,而這些操作主要是通過(guò)JS來(lái)監(jiān)聽video的事件和對(duì)video屬性的讀寫來(lái)完成的,熟悉這四點(diǎn)即可靈活的在使用播放器,再根據(jù)應(yīng)用場(chǎng)景來(lái)調(diào)整即可。

關(guān)于“HTML5 video標(biāo)簽播放控制的技巧有哪些”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

文章標(biāo)題:HTML5video標(biāo)簽播放控制的技巧有哪些
標(biāo)題路徑:http://www.muchs.cn/article34/ihpgse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、關(guān)鍵詞優(yōu)化、移動(dòng)網(wǎng)站建設(shè)、商城網(wǎng)站網(wǎng)站制作、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)