有关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 相关文章推荐
CSS心形加载的动画源码的实现
Mar 09 HTML / CSS
css3 box-sizing属性使用参考指南
Jan 08 HTML / CSS
可以随进度显示不同颜色的css3进度条分享
Apr 11 HTML / CSS
全方位了解CSS3的Regions扩展
Aug 07 HTML / CSS
使用CSS3制作版头动画效果
Dec 24 HTML / CSS
Html5之svg可缩放矢量图形_动力节点Java学院整理
Jul 17 HTML / CSS
html5 利用canvas手写签名并保存的实现方法
Jul 12 HTML / CSS
HTML5边玩边学(2)基础绘图实现方法
Sep 21 HTML / CSS
Html5百叶窗效果的示例代码
Dec 11 HTML / CSS
html+css 实现简易导航栏功能
Apr 07 HTML / CSS
详解盒子端CSS动画性能提升
May 24 HTML / CSS
HTML5页面打开微信小程序功能实现
Sep 23 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 采集程序中常用的函数
2009/12/09 PHP
ThinkPHP模板范围判断输出In标签与Range标签用法详解
2014/06/30 PHP
PHP中的静态变量及static静态变量使用详解
2015/11/05 PHP
CodeIgniter针对数据库的连接、配置及使用方法
2016/03/03 PHP
Symfony2针对输入时间进行查询的方法分析
2017/06/28 PHP
自动生成文章摘要的代码[JavaScript 版本]
2007/03/20 Javascript
随机显示经典句子或诗歌的javascript脚本
2007/08/04 Javascript
关于js获取radio和select的属性并控制的代码
2011/05/12 Javascript
js replace正则表达式应用案例讲解
2013/01/17 Javascript
jQuery实现可用于博客的动态滑动菜单
2015/03/09 Javascript
学习JavaScript正则表达式
2015/11/13 Javascript
使用jQuery中的wrap()函数操作HTML元素的教程
2016/05/24 Javascript
微信小程序 摇一摇抽奖简单实例实现代码
2017/01/09 Javascript
信息滚动效果的实例讲解
2017/09/18 Javascript
js中值引用和地址引用实例分析
2019/06/21 Javascript
实例讲解Python中SocketServer模块处理网络请求的用法
2016/06/28 Python
Django框架model模型对象验证实现方法分析
2019/10/02 Python
使用Python给头像加上圣诞帽或圣诞老人小图标附源码
2019/12/25 Python
利用PyTorch实现VGG16教程
2020/06/24 Python
Brookstone美国官网:独特新奇产品
2017/03/04 全球购物
潘多拉意大利官方网上商城:网上选购PANDORA珠宝
2018/10/07 全球购物
Manuka Doctor英国官网:真正的麦卢卡蜂蜜和护肤品
2018/10/26 全球购物
英国No.1体育用品零售商:SportsDirect.com
2019/10/16 全球购物
写clone()方法时,通常都有一行代码,是什么?
2012/10/31 面试题
化学实验员岗位职责
2013/12/28 职场文书
护理个人求职信范文
2014/01/08 职场文书
高级销售求职信
2014/02/21 职场文书
大学社团招新的通讯稿
2014/09/10 职场文书
幼儿园迎国庆65周年活动策划方案
2014/09/16 职场文书
美术教师个人总结
2015/02/06 职场文书
生日宴会祝酒词
2015/08/10 职场文书
安全教育的主题班会
2015/08/13 职场文书
幽默导游词应该怎么写?
2019/08/26 职场文书
python 破解加密zip文件的密码
2021/04/22 Python
Python 一键获取电脑浏览器的账号密码
2022/05/11 Python
vscode内网访问服务器的方法
2022/06/28 Servers