上一篇介紹了html5標籤video(播放器)初始化需要做的一些工作,如何簡單快速使用html5的播放器,本文將重點介紹如何用JS來操作video標籤,也就是如何對video做一些簡單基本的操作,包括了播放器的播放、暫停,音量的讀取、設定等寫相關操作,從而開始播放器的擴展之路。
本文的目錄:
1.取得影片總時長
2.播放、暫停
3.取得影片已播放時間和設定播放點
4.音量的取得與設定
第一、取得影片總時長
對播放器(video)操作,首先要得到的是影片的一些訊息,其中一個就是總時長,除了內容以為,總時長也是第一時間要顯示的。在video進行操作的前先為video標籤加入ID,這樣方便我們取得video元素
複製程式碼
複製程式碼
代碼如下:
tol = myVideo.duration;//取得總時長
});
要注意的是取得到的在總時長的單位為秒,顯示的時候依需求去轉換。
第二、播放、暫停
複製代碼
代碼如下:
var myVideo = document.getElementById('myVideo')//取得video元素
,tol = 0
;
myVideo.addEventListener("loadedmetadata", function(){
tol = myVideo.duration;//取得總時長
});
//播放
function play(){
myVideo.play();
}
//暫停
function pause(){
myVideo.pause(); }
需要注意的是,當播放結束後再執行play方法將會從頭播放。
第三、取得影片的播放時間與設定播放點
複製程式碼
程式碼如下:
//播放時間點更新時
myVideo.addEventListener("timeupdate", function(){
myVideo.addEventListener("timeupdate", function(){ var currentTime = myVideo.currentTime;//取得目前播放時間 console.log(currentTime);//在偵錯器中列印});
運作後會在控制台看到很多資料...
我們常常會接到一個要求,那就是上次看到了10分鐘了,這次看要從第十分鐘開始看,那麼這個時候就需要設定播放點了,設定播放點用得還是currentTime屬性,currentTime屬性是可讀寫的,要注意的是設定值的單位是秒,如果播放點不是秒為單位那就要進行轉換
//設定播放點
function playBySeconds(num){
mynum.currentTime = num;
}
第四、音量的取得與設定
播放器播放的過程中能暫停、播放,知道現在播放到哪裡了和可以從某個時間點開始播放,那麼接下來操作的就是音量了。這點跟第三相似,取得音量可以直接用volume屬性就可以了,但是這裡還要介紹的是音量改變的觸發事件,方面以後需要自訂UI使用,那就是volumechange事件
//音量改變時
myVideo.addEventListListener("volume" , function(){
var volume = myVideo.volume;//取得目前音量
console.log(volume);//在偵錯器中列印
});
當你透過控制條來改變音量時,你會看到除錯裡面有很多資料。要注意的是音量的範圍值為0~1,一般在UI中都是用百分比,所以需要的時候要進行轉換。
音量是可以透過改變屬性來設定的,跟播放的時間點是相似的,只不過音量設定的是volume屬性
//設定音量
function setVol(num){
myVideo.volume = num;
}
}
以下是完整的程式碼:
程式碼
Video step2
poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg"
src="http://www.w3cschool.cc/try/demo_mp/mov> 🎜>
<script><br />var myVideo = document.getElementById('myVideo')//取得video元素<br /> ,tol = 0 //總長度<br />;<br />myVideo .addEventListener("loadedmetadata", function(){<br /> tol = myVideo.duration;//取得總時長<br />});
<p>//播放<br />function play(){ <br /> myVideo.play();<br />}
<p>//暫停<br />function pause(){ <br /> myVideo.pause();<br />}
<p>//播放時間點更新時<br />myVideo.addEventListener("timeupdate", function(){<br /> var currentTime = myVideo.currentTime;//取得目前播放時間<br /> console.log(currentTime) ;//在偵錯器中列印<br />});
<p>//設定播放點<br />function playBySeconds(num){ <br /> myVideo.currentTime = num;<br />}
<p>//音量改變時<br />myVideo.addEventListener("volumechange", function(){<br /> var volume = myVideo.volume;//取得目前音量<br /> console.log(volume);//在調試器中列印<br />});
<p>//設定音量<br />function setVol(num){ <br /> myVideo.volume = num;<br />}<br /></script>
總結:透過這四個步驟來了解html5標籤video(播放器)的基本操作,而這些操作主要是透過JS來監聽video的事件和對video屬性的讀寫來完成的,熟悉這四點即可靈活的在使用播放器,再根據應用場景來調整即可。