有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题


Posted in HTML / CSS onJuly 19, 2013

日期在做一个视频播放的页面,其中用到了HTML5的Video对象,这个是HTML5中新增的一个对象,支持多种不同格式的视频在线播放,功能比较强大,而且还扩展了许多事件,可以通过JavaScript脚本来对视频播放进行控制。参考下面两个链接:
http://msdn.microsoft.com/en-us/library/windows/apps/hh465962.aspx
http://www.w3school.com.cn/html5/tag_video.asp

Video对象可以通过ontimeupdate事件来报告当前的播放进度,同时通过该事件还可以根据视频播放的情况来控制页面上的其它元素,例如随着视频播放的进度来切换章节、显示额外信息等。下面是一个例子:

复制代码
代码如下:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<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浏览器,所以应该是通过的。
HTML / CSS 相关文章推荐
css3动画效果抖动解决方法
Sep 03 HTML / CSS
css3 中实现炫酷的loading效果
Apr 26 HTML / CSS
CSS3伪类选择器:nth-child()
Apr 02 HTML / CSS
基于CSS3特效之动画:animation的应用
May 09 HTML / CSS
前端隐藏出边界内容的实现方法
Apr 14 HTML / CSS
移动端适配 使px自动转换rem
Aug 26 HTML / CSS
css3给背景图片加颜色遮罩的方法
Nov 05 HTML / CSS
深入剖析webstorage[html5的本地数据处理]
Jul 11 HTML / CSS
用HTML5的canvas实现一个炫酷时钟效果
May 20 HTML / CSS
css 中多种边框的实现小窍门
Apr 07 HTML / CSS
CSS3 实现NES游戏机的示例代码
Apr 21 HTML / CSS
企业开发CSS命名BEM代码规范实践
Feb 12 HTML / CSS
HTML5 的新的表单元素(datalist/keygen/output)使用介绍
Jul 19 #HTML / CSS
HTML5注册表单的自动聚焦与占位文本示例代码
Jul 19 #HTML / CSS
HTML5标签与HTML4标签的区别示例介绍
Jul 18 #HTML / CSS
html5 音乐播放器 audio 标签使用概述
Jul 15 #HTML / CSS
HTML5 Canvas如何实现纹理填充与描边(Fill And Stroke)
Jul 15 #HTML / CSS
css 如何让背景图片拉伸填充避免重复显示
Jul 11 #HTML / CSS
HTML5 Canvas渐进填充与透明实现图像的Mask效果
Jul 11 #HTML / CSS
You might like
php 检查电子邮件函数(自写)
2014/01/16 PHP
ThinkPHP之foreach标签使用概述
2014/06/30 PHP
推荐几款用 Sublime Text 开发 Laravel 所用到的插件
2014/10/30 PHP
PHP执行系统命令函数实例讲解
2021/03/03 PHP
在修改准备发的批量美化select+可修改select时,在非IE下发现了几个问题
2007/01/09 Javascript
js可突破windows弹退效果代码
2008/08/09 Javascript
跟着Jquery API学Jquery之一 选择器
2010/04/07 Javascript
Jquery + Ajax调用webService实例代码(asp.net)
2010/08/27 Javascript
打印json对象的内容及JSON.stringify函数应用
2013/03/29 Javascript
深入Javascript函数、递归与闭包(执行环境、变量对象与作用域链)使用详解
2013/05/08 Javascript
基于mouseout和mouseover等类似事件的冒泡问题解决方法
2013/11/18 Javascript
网页右侧悬浮滚动在线qq客服代码示例
2014/04/28 Javascript
js鼠标按键事件和键盘按键事件用法实例汇总
2016/10/03 Javascript
Nodejs下DNS缓存问题浅析
2016/11/16 NodeJs
jquery.flot.js简单绘制折线图用法示例
2017/03/13 Javascript
带你了解session和cookie作用原理区别和用法
2017/08/14 Javascript
JS实现自定义状态栏动画文字效果示例
2017/10/12 Javascript
对mac下nodejs 更新到最新版本的最新方法(推荐)
2018/05/17 NodeJs
写一个Vue Popup组件
2019/02/25 Javascript
Vue实现点击按钮复制文本内容的例子
2019/11/09 Javascript
JS+CSS实现3D切割轮播图
2020/03/21 Javascript
[00:32]2018DOTA2亚洲邀请赛VG出场
2018/04/03 DOTA
[01:52]2020年DOTA2 TI10夏季活动预告片
2020/07/15 DOTA
如何优雅地处理Django中的favicon.ico图标详解
2018/07/05 Python
python实现祝福弹窗效果
2019/04/07 Python
pyqt5实现按钮添加背景图片以及背景图片的切换方法
2019/06/13 Python
Python计算机视觉里的IOU计算实例
2020/01/17 Python
python numpy生成等差数列、等比数列的实例
2020/02/25 Python
python opencv进行图像拼接
2020/03/27 Python
马来西亚最热门的在线时尚商店:FashionValet
2018/11/11 全球购物
德国旅行、体验和活动的预订平台:Watado
2019/12/04 全球购物
财务出纳岗位职责
2014/02/03 职场文书
小学生操行评语大全
2014/04/22 职场文书
工程学毕业生自荐信
2014/06/14 职场文书
给老师的感谢信
2015/01/20 职场文书
JVM之方法返回地址详解
2022/02/28 Java/Android