http://msdn.microsoft.com/en-us/library/windows/apps/hh465962.aspx
http://www.51sjk.com/Upload/Articles/1/0/280/280450_20210709000305408.asp
video对象可以通过ontimeupdate事件来报告当前的播放进度,同时通过该事件还可以根据视频播放的情况来控制页面上的其它元素,例如随着视频播放的进度来切换章节、显示额外信息等。下面是一个例子:
复制代码
代码如下:<!doctype html>
<html xmlns="http://www.51sjk.com/Upload/Articles/1/0/280/280450_20210709000305423.jpg">
<head>
<meta http-equiv="x-ua-compatible" content="ie=edge" />
<title></title>
</head>
<body>
<script type="text/javascript">
function timeupdate() {
document.getelementbyid('time').innerhtml = video.currenttime;
}
function durationchange() {
document.getelementbyid('duration').innerhtml = video.duration;
}
function seekvideo() {
document.getelementbyid('video').currenttime = document.getelementbyid('seektext').value;
}
window.onload = function () {
var videoplayer = document.getelementbyid("video");
videoplayer.ontimeupdate = function () { timeupdate(); };
};
</script>
<div>
<video id="video" controls="controls"
poster="./images/videoground1.png"
src="./videosource/video1.mp4" width="450px" height="320px"
ondurationchange="durationchange()" />
</div>
<div>time: <span id="time">0</span> of <span id="duration">0</span> seconds.</div>
<div>
<input type="text" id="seektext" />
<input type="button" id="seekbtn" value="seek video" onclick="seekvideo();" />
</div>
</body>
</html>
当然你也可以像在页面上使用其它元素一样,给video对象动态添加属性或者挂事件,如:
复制代码
代码如下:video.ontimeupdate = function () { getcurrentvideoposition(); };
不过上面这行代码貌似在chrome上无效,可以使用addeventlistener来代替它:
复制代码
代码如下:videoplayer.addeventlistener("timeupdate", function () { getcurrentvideoposition(); }, false);
不知道是什么原因在chrome上不能直接将ontimeupdate事件挂在video元素上,而必须通过addeventlistener方法来添加事件。不过addeventlistener也兼容ie和firefox浏览器,所以应该是通过的。