91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5中video標簽如何實現播放控制

發布時間:2020-12-05 10:42:15 來源:億速云 閱讀:367 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關HTML5中video標簽如何實現播放控制,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

html5標簽video(播放器)初始化需要做的一些工作,如何簡單快速使用html5的播放器,本文將重點介紹如何用JS來操作video標簽,也就是如何對video做一些簡單基本的操作,包括了播放器的播放、暫停,音量的讀取、設置等寫相關操作,從而開始播放器的擴展之路。

本文的目錄:  

1.獲取影片總時長
2.播放、暫停
3.獲取影片已播放時間和設置播放點
4.音量的獲取和設置

第一、獲取影片總時長

對播放器(video)操作,首先要得到的是影片的一些信息,其中一個就是總時長,除了內容以為,總時長也是第一時間要顯示的。在對video進行操作的的前先給video標簽添加一個ID,這樣方便我們獲取video元素

<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>

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

var myVideo = document.getElementById('myVideo');//獲取video元素
myVideo.addEventListener("loadedmetadata", function(){
    //要執行的代碼
});
     好了,已經監聽了,那么接下來要做的就是獲取總時長,其實就是一個屬性-duration
var myVideo = document.getElementById('myVideo')//獲取video元素
    ,tol = 0
;
myVideo.addEventListener("loadedmetadata", function(){
    tol = myVideo.duration;//獲取總時長
});

需要注意的是獲取到的在總時長的單位為秒,顯示的時候根據需要去轉換。

第二、播放、暫停

對播放器來說最基本的一個功能就是播放和暫停了,而在獲取總時長后,接著的操作也就是播放和暫停。這個時候用到了video的兩個方法就是play和pause

var myVideo = document.getElementById('myVideo')//獲取video元素
    ,tol = 0
;
myVideo.addEventListener("loadedmetadata", function(){
  tol = myVideo.duration;//獲取總時長
 });</p>
<p> //播放
 function play(){ 
     myVideo.play();
 }</p>
<p> //暫停
 function pause(){ 
     myVideo.pause();
 }

需要注意的是,當播放結束后再運行play方法將會從頭播放。

 第三、獲取影片的播放時間和設置播放點

播放器能播放和暫停后,那么接下來需要看到的就是影片播放了多久,播放到哪個時間點了。這個操作跟獲取總時長很相似,都是需要監聽一個事件和獲取一個屬性的值,那么用到的是video的timeupdate事件和currentTime屬性

//播放時間點更新時
myVideo.addEventListener("timeupdate", function(){
   var currentTime = myVideo.currentTime;//獲取當前播放時間
   console.log(currentTime);//在調試器中打印
});

運行后會在控制臺看到很多數據...

我們經常會接到一個要求,那就是上次看到了10分鐘了,這次看要從第十分鐘開始看,那么這個時候就需要設置播放點了,設置播放點用得還是currentTime屬性,currentTime屬性是可讀寫的,要注意的是設置值的單位是秒,如果播放點不是秒為單位那就要進行轉換

//設置播放點
function playBySeconds(num){ 
    myVideo.currentTime = num;
}

   第四、音量的獲取和設置

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

//音量改變時
myVideo.addEventListener("volumechange", function(){
   var volume = myVideo.volume;//獲取當前音量
   console.log(volume);//在調試器中打印
});

當你通過控制條來改變音量時,你會看到調試里面有很多數據。要注意的是音量的范圍值為0~1,一般在UI中都是用百分比,所以需要的時候要進行轉換。

音量是可以通過改變屬性來設置的,跟播放的時間點是相似的,只不過音量設置的是volume屬性

//設置音量
function setVol(num){ 
   myVideo.volume = num;
}

下面是完整的代碼:

<!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 //總時長
;
myVideo.addEventListener("loadedmetadata", function(){
   tol = myVideo.duration;//獲取總時長
});</p> <p>//播放
function play(){ 
   myVideo.play();
}</p> <p>//暫停
function pause(){ 
   myVideo.pause();
}</p> <p>//播放時間點更新時
myVideo.addEventListener("timeupdate", function(){
   var currentTime = myVideo.currentTime;//獲取當前播放時間
   console.log(currentTime);//在調試器中打印
});</p> <p>//設置播放點
function playBySeconds(num){ 
   myVideo.currentTime = num;
}</p> <p>//音量改變時
myVideo.addEventListener("volumechange", function(){
   var volume = myVideo.volume;//獲取當前音量
   console.log(volume);//在調試器中打印
});</p> <p>//設置音量
function setVol(num){ 
   myVideo.volume = num;
}
</script>
</body>
</html>


   總結:通過這四個步驟來了解html5標簽video(播放器)的基本操作,而這些操作主要是通過JS來監聽video的事件和對video屬性的讀寫來完成的,熟悉這四點即可靈活的在使用播放器,再根據應用場景來調整即可。

關于HTML5中video標簽如何實現播放控制就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

柏乡县| 龙山县| 会宁县| 铜川市| 尉犁县| 元阳县| 布拖县| 甘南县| 新河县| 永善县| 上饶市| 志丹县| 萝北县| 长沙市| 精河县| 广灵县| 宾阳县| 台中市| 萝北县| 长宁区| 进贤县| 余干县| 北安市| 饶河县| 土默特左旗| 冷水江市| 博爱县| 龙山县| 双峰县| 永昌县| 汉中市| 三原县| 象州县| 阿鲁科尔沁旗| 西平县| 襄城县| 沿河| 大埔县| 巴林右旗| 格尔木市| 政和县|