濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫(kù) > HTML5 video標(biāo)簽(播放器)學(xué)習(xí)筆記(二):播放控制

HTML5 video標(biāo)簽(播放器)學(xué)習(xí)筆記(二):播放控制

熱門標(biāo)簽:外呼系統(tǒng)電話怎么投訴 申請(qǐng)400電話流程簡(jiǎn)介 pageadm實(shí)現(xiàn)地圖標(biāo)注 外呼線穩(wěn)定線路 邢臺(tái)縣地圖標(biāo)注app 呼和浩特外呼電銷系統(tǒng)排名 地圖標(biāo)注位置能賺錢嗎 阜陽企業(yè)外呼系統(tǒng) 南通數(shù)據(jù)外呼系統(tǒng)推廣

上一篇介紹了html5標(biāo)簽video(播放器)初始化需要做的一些工作,如何簡(jiǎn)單快速使用html5的播放器,本文將重點(diǎn)介紹如何用JS來操作video標(biāo)簽,也就是如何對(duì)video做一些簡(jiǎn)單基本的操作,包括了播放器的播放、暫停,音量的讀取、設(shè)置等寫相關(guān)操作,從而開始播放器的擴(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元素

復(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)聽了,那么接下來要做的就是獲取總時(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ì)播放器來說最基本的一個(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)

    播放器能播放和暫停后,那么接下來需要看到的就是影片播放了多久,播放到哪個(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è)置

    播放器播放的過程中能暫停、播放,知道現(xiàn)在播放到哪里了和可以從某個(gè)時(shí)間點(diǎn)開始播放,那么接下來操作的就是音量了。這一點(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)你通過控制條來改變音量時(shí),你會(huì)看到調(diào)試?yán)锩嬗泻芏鄶?shù)據(jù)。要注意的是音量的范圍值為0~1,一般在UI中都是用百分比,所以需要的時(shí)候要進(jìn)行轉(zhuǎn)換。

    音量是可以通過改變屬性來設(shè)置的,跟播放的時(shí)間點(diǎn)是相似的,只不過音量設(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é):通過這四個(gè)步驟來了解html5標(biāo)簽video(播放器)的基本操作,而這些操作主要是通過JS來監(jiān)聽video的事件和對(duì)video屬性的讀寫來完成的,熟悉這四點(diǎn)即可靈活的在使用播放器,再根據(jù)應(yīng)用場(chǎng)景來調(diào)整即可。

標(biāo)簽:蚌埠 黃山 撫順 楊凌 辛集 內(nèi)蒙古 德州 鶴崗

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5 video標(biāo)簽(播放器)學(xué)習(xí)筆記(二):播放控制》,本文關(guān)鍵詞  HTML5,video,標(biāo)簽,播放器,學(xué)習(xí),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5 video標(biāo)簽(播放器)學(xué)習(xí)筆記(二):播放控制》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5 video標(biāo)簽(播放器)學(xué)習(xí)筆記(二):播放控制的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    阿荣旗| 瓮安县| 西乌珠穆沁旗| 柳林县| 环江| 湄潭县| 昌乐县| 杭州市| 平泉县| 迁安市| 岳池县| 永仁县| 锡林浩特市| 鞍山市| 商水县| 武义县| 梁平县| 泰安市| 正安县| 兴海县| 保定市| 苏州市| 宁南县| 彰武县| 武威市| 东乌珠穆沁旗| 全椒县| 张家口市| 宁城县| 兰坪| 连平县| 清水县| 武夷山市| 黄大仙区| 柘荣县| 陈巴尔虎旗| 双柏县| 奎屯市| 海宁市| 诸城市| 饶平县|