有关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新特性应用之过渡与动画
Jan 10 HTML / CSS
让IE可以变相支持CSS3选择器
Jan 21 HTML / CSS
使用css3实现的windows8开机加载动画
Dec 09 HTML / CSS
CSS3色彩模式有哪些?CSS3 HSL色彩模式的定义
Apr 26 HTML / CSS
仿CSDN Blog返回页面顶部功能实现原理及代码
Jun 30 HTML / CSS
html5 canvas fillRect坐标和大小的问题解决方法
Mar 26 HTML / CSS
HTML5的download属性详细介绍和使用实例
Apr 23 HTML / CSS
HTML5新特性之用SVG绘制微信logo
Feb 03 HTML / CSS
HTML5 canvas基本绘图之绘制曲线
Jun 27 HTML / CSS
HTML5中的Web Notification桌面通知功能的实现方法
Jul 29 HTML / CSS
关于iframe跨域使用postMessage的实现
Oct 29 HTML / CSS
使用layui框架实现点击左侧导航切换右侧内容且右侧选项卡跟随变化的效果
Nov 10 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函数之日期时间函数date()使用详解
2013/09/09 PHP
ThinkPHP之R方法实例详解
2014/06/20 PHP
浅谈PHP匿名函数和闭包
2019/03/08 PHP
javascript iframe中打开文件,并检测iframe存在否
2008/12/28 Javascript
ExtJs之带图片的下拉列表框插件
2010/03/04 Javascript
javascript下判断一个元素是否存在的代码
2010/03/05 Javascript
juqery 学习之五 文档处理 插入
2011/02/11 Javascript
可在线编辑网页文字效果代码(单击)
2013/03/02 Javascript
JavaScript bold方法入门实例(把指定文字显示为粗体)
2014/10/17 Javascript
javascript数据类型示例分享
2015/01/19 Javascript
javascript:void(0)是什么意思及href=#与href=javascriptvoid(0)的区别
2015/11/13 Javascript
JS简单实现String转Date的方法
2016/03/02 Javascript
vue2.0开发实践总结之入门篇
2016/12/06 Javascript
浅析上传头像示例及其注意事项
2016/12/14 Javascript
jQuery实现点击图标div循环放大缩小功能
2018/09/30 jQuery
小程序云开发初探(小结)
2018/10/24 Javascript
微信小程序官方动态自定义底部tabBar的例子
2019/09/04 Javascript
vue-cli设置css不生效的解决方法
2020/02/07 Javascript
three.js 将图片马赛克化的示例代码
2020/07/31 Javascript
vue组件开发之tab切换组件使用详解
2020/08/21 Javascript
[04:12]第二届DOTA2亚洲邀请赛选手传记-Newbee.Sccc
2017/04/03 DOTA
[01:20]PWL开团时刻DAY9——听说潮汐没用?
2020/11/10 DOTA
python基于mysql实现的简单队列以及跨进程锁实例详解
2014/07/07 Python
Python 模拟购物车的实例讲解
2017/09/11 Python
python 读取.csv文件数据到数组(矩阵)的实例讲解
2018/06/14 Python
使用Python机器学习降低静态日志噪声
2018/09/29 Python
基于django ManyToMany 使用的注意事项详解
2019/08/09 Python
解决html5中的video标签ios系统中无法播放使用的问题
2020/08/10 HTML / CSS
荷兰本土平价百货:HEMA
2017/10/23 全球购物
财务主管自我鉴定
2014/01/17 职场文书
服装创业计划书范文
2014/02/05 职场文书
死亡证明书样本说明
2014/10/18 职场文书
初中作文评语集锦
2014/12/25 职场文书
药店收银员岗位职责
2015/04/07 职场文书
vue基于Teleport实现Modal组件
2021/05/31 Vue.js
java调用Restful接口的三种方法
2021/08/23 Java/Android