html5中文学习网

您的位置: 首页 > html5教程 > 入门教程 » 正文

有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题 _html5教程技巧

[ ] 已经帮助:人解决问题
点评:Video对象是HTML5中新增的一个对象,支持多种不同格式的视频在线播放,功能比较强大,Video对象可以通过ontimeupdate事件来报告当前的播放进度,下面为大家介绍下Video对象ontimeupdate事件的问题,感兴趣的朋友可以参考下哈
日期在做一个视频播放的页面,其中用到了HTML5的Video对象,这个是HTML5中新增的一个对象,支持多种不同格式的视频在线播放,功能比较强大,而且还扩展了许多事件,可以通过JavaScript脚本来对视频播放进行控制。参考下面两个链接: xNWHTML5中文学习网 - HTML5先行者学习网
http://msdn.microsoft.com/en-us/library/windows/apps/hh465962.aspx xNWHTML5中文学习网 - HTML5先行者学习网
http://www.w3school.com.cn/html5/tag_video.asp xNWHTML5中文学习网 - HTML5先行者学习网
xNWHTML5中文学习网 - HTML5先行者学习网
Video对象可以通过ontimeupdate事件来报告当前的播放进度,同时通过该事件还可以根据视频播放的情况来控制页面上的其它元素,例如随着视频播放的进度来切换章节、显示额外信息等。下面是一个例子: xNWHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
xNWHTML5中文学习网 - HTML5先行者学习网
<!DOCTYPE html> xNWHTML5中文学习网 - HTML5先行者学习网
<html xmlns="http://www.w3.org/1999/xhtml"> xNWHTML5中文学习网 - HTML5先行者学习网
<head> xNWHTML5中文学习网 - HTML5先行者学习网
<meta http-equiv="X-UA-Compatible" content="IE=Edge" /> xNWHTML5中文学习网 - HTML5先行者学习网
<title></title> xNWHTML5中文学习网 - HTML5先行者学习网
</head> xNWHTML5中文学习网 - HTML5先行者学习网
<body> xNWHTML5中文学习网 - HTML5先行者学习网
<script type="text/javascript"> xNWHTML5中文学习网 - HTML5先行者学习网
function timeUpdate() { xNWHTML5中文学习网 - HTML5先行者学习网
document.getElementById('time').innerHTML = video.currentTime; xNWHTML5中文学习网 - HTML5先行者学习网
} xNWHTML5中文学习网 - HTML5先行者学习网
function durationChange() { xNWHTML5中文学习网 - HTML5先行者学习网
document.getElementById('duration').innerHTML = video.duration; xNWHTML5中文学习网 - HTML5先行者学习网
} xNWHTML5中文学习网 - HTML5先行者学习网
function seekVideo() { xNWHTML5中文学习网 - HTML5先行者学习网
document.getElementById('video').currentTime = document.getElementById('seekText').value; xNWHTML5中文学习网 - HTML5先行者学习网
} xNWHTML5中文学习网 - HTML5先行者学习网
window.onload = function () { xNWHTML5中文学习网 - HTML5先行者学习网
var videoPlayer = document.getElementById("video"); xNWHTML5中文学习网 - HTML5先行者学习网
videoPlayer.ontimeupdate = function () { timeUpdate(); }; xNWHTML5中文学习网 - HTML5先行者学习网
}; xNWHTML5中文学习网 - HTML5先行者学习网
</script> xNWHTML5中文学习网 - HTML5先行者学习网
<div> xNWHTML5中文学习网 - HTML5先行者学习网
<video id="video" controls="controls" xNWHTML5中文学习网 - HTML5先行者学习网
poster="./images/videoground1.png" xNWHTML5中文学习网 - HTML5先行者学习网
src="./videoSource/video1.mp4" width="450px" height="320px" xNWHTML5中文学习网 - HTML5先行者学习网
ondurationchange="durationChange()" /> xNWHTML5中文学习网 - HTML5先行者学习网
</div> xNWHTML5中文学习网 - HTML5先行者学习网
<div>Time: <span id="time">0</span> of <span id="duration">0</span> seconds.</div> xNWHTML5中文学习网 - HTML5先行者学习网
<div> xNWHTML5中文学习网 - HTML5先行者学习网
<input type="text" id="seekText" /> xNWHTML5中文学习网 - HTML5先行者学习网
<input type="button" id="seekBtn" value="Seek Video" onclick="seekVideo();" /> xNWHTML5中文学习网 - HTML5先行者学习网
</div> xNWHTML5中文学习网 - HTML5先行者学习网
</body> xNWHTML5中文学习网 - HTML5先行者学习网
</html> xNWHTML5中文学习网 - HTML5先行者学习网
xNWHTML5中文学习网 - HTML5先行者学习网
当然你也可以像在页面上使用其它元素一样,给Video对象动态添加属性或者挂事件,如: xNWHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
xNWHTML5中文学习网 - HTML5先行者学习网
video.ontimeupdate = function () { getCurrentVideoPosition(); }; xNWHTML5中文学习网 - HTML5先行者学习网
xNWHTML5中文学习网 - HTML5先行者学习网
不过上面这行代码貌似在Chrome上无效,可以使用addEventListener来代替它: xNWHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
xNWHTML5中文学习网 - HTML5先行者学习网
videoPlayer.addEventListener("timeupdate", function () { getCurrentVideoPosition(); }, false); xNWHTML5中文学习网 - HTML5先行者学习网
xNWHTML5中文学习网 - HTML5先行者学习网
不知道是什么原因在Chrome上不能直接将ontimeupdate事件挂在Video元素上,而必须通过addEventListener方法来添加事件。不过addEventListener也兼容IE和Firefox浏览器,所以应该是通过的。xNWHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助