有关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实现背景模糊的三种方式
Mar 09 HTML / CSS
详解CSS3 弹性布局快速入门
Jun 06 HTML / CSS
CSS3中Color的一些特性介绍
May 27 HTML / CSS
CSS+jQuery+PHP+MySQL实现的在线答题功能
Apr 25 HTML / CSS
HTML 5 input placeholder 属性如何完美兼任ie
May 12 HTML / CSS
Html5新特性用canvas标签画多条直线附效果截图
Jun 30 HTML / CSS
用HTML5制作一个简单的桌球游戏的教程
May 12 HTML / CSS
HTML5实现动画效果的方式汇总
Feb 29 HTML / CSS
小程序canvas中文字设置居中锚点
Apr 16 HTML / CSS
data:image data url 文件转为Blob上传后端的方法
Jul 16 HTML / CSS
详解淘宝H5 sign加密算法
Aug 25 HTML / CSS
浅析HTML5 Landmark
Sep 11 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
javascript实现的一个随机点名功能
2014/08/26 Javascript
js获取字符串最后一位方法汇总
2014/11/13 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
2015/03/13 Javascript
jQuery实现冻结表格行和列
2015/04/29 Javascript
JavaScript中操作字符串小结
2015/05/04 Javascript
Knockout自定义绑定创建方法
2015/12/26 Javascript
基于javascript数组实现图片轮播
2016/05/02 Javascript
JS与jQuery实现隔行变色的方法
2016/09/09 Javascript
jQuery控制控件文本的长度的操作方法
2016/12/05 Javascript
使用jsonp实现跨域获取数据实例讲解
2016/12/25 Javascript
谈谈对vue响应式数据更新的误解
2017/08/01 Javascript
解决iview打包时UglifyJs报错的问题
2018/03/07 Javascript
微信小程序如何调用新闻接口实现列表循环
2019/07/02 Javascript
Vue看了就会的8个小技巧
2021/01/21 Vue.js
详解Python中列表和元祖的使用方法
2015/04/25 Python
Python批量更改文件名的实现方法
2017/10/29 Python
Python获取当前函数名称方法实例分享
2018/01/18 Python
利用Python代码实现数据可视化的5种方法详解
2018/03/25 Python
Python3.5常见内置方法参数用法实例详解
2019/04/29 Python
Python利用scapy实现ARP欺骗的方法
2019/07/23 Python
python 监测内存和cpu的使用率实例
2019/11/28 Python
Python Pillow.Image 图像保存和参数选择方式
2020/01/09 Python
Python基于百度AI实现OCR文字识别
2020/04/02 Python
Python第三方库的几种安装方式(小结)
2020/04/03 Python
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
美国探亲签证邀请信
2014/02/05 职场文书
优良学风班总结材料
2014/02/08 职场文书
护理助产毕业生的求职信
2014/03/02 职场文书
综合测评自我评价
2015/03/06 职场文书
求职信范文怎么写
2015/03/19 职场文书
首都博物馆观后感
2015/06/05 职场文书
上甘岭观后感
2015/06/10 职场文书
2019七夕节祝福语36句,快来收藏吧
2019/08/06 职场文书
多表查询、事务、DCL
2021/04/05 MySQL
mysql字段为NULL索引是否会失效实例详解
2022/05/30 MySQL
MyBatis在注解上使用动态SQL方式(@select使用if)
2022/07/07 Java/Android