有关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的border边框属性及其在CSS3中的新特性
May 10 HTML / CSS
button在IE6/7下的黑边去除方案
Dec 24 HTML / CSS
CSS中几个与换行有关的属性简明总结
Apr 15 HTML / CSS
基于CSS3实现立方体自转效果
Mar 01 HTML / CSS
CSS3 分类菜单效果
May 27 HTML / CSS
css3实现蒙版弹幕功能
Jun 18 HTML / CSS
一张图片能隐含千言万语之隐藏你的程序代码
Dec 13 HTML / CSS
HTML5 CSS3打造相册效果附源码下载
Jun 16 HTML / CSS
html5需遵循的6个设计原则
Apr 27 HTML / CSS
HTML5中使用postMessage实现两个网页间传递数据
Jun 22 HTML / CSS
html5 canvas实现给图片添加平铺水印
Aug 20 HTML / CSS
AmazeUI 缩略图的实现示例
Aug 18 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中限制IP段访问、禁止IP提交表单的代码
2011/04/23 PHP
smarty学习笔记之常见代码段用法总结
2016/03/19 PHP
用js得到网页中所有的div的id
2020/10/19 Javascript
用JS实现一个TreeMenu效果分享
2011/08/28 Javascript
escape函数解决js中ajax传递中文出现乱码问题
2014/10/30 Javascript
jQuery判断多个input file 都不能为空的例子
2015/06/23 Javascript
jQuery实现网站添加高亮突出显示效果的方法
2015/06/26 Javascript
学习Bootstrap组件之下拉菜单
2015/07/28 Javascript
如何屏蔽防止别的网站嵌入框架代码
2015/08/24 Javascript
Bootstrap每天必学之进度条
2015/11/30 Javascript
BootStrap智能表单实战系列(六)表单编辑页面的数据绑定
2016/06/13 Javascript
js点击任意区域弹出层消失实现代码
2016/12/27 Javascript
Vue-Router实现页面正在加载特效方法示例
2017/02/12 Javascript
JS 验证密码 不能为空,必须含有数字、字母、特殊字符,长度在8-12位
2017/06/21 Javascript
深入理解JS异步编程-Promise
2019/06/03 Javascript
Vue的属性、方法、生命周期实例代码详解
2019/09/17 Javascript
在vue中根据光标的显示与消失实现下拉列表
2019/09/29 Javascript
jstree中的checkbox默认选中和隐藏示例代码
2019/12/29 Javascript
通过实例解析javascript Date对象属性及方法
2020/11/04 Javascript
pycharm 使用心得(八)如何调用另一文件中的函数
2014/06/06 Python
Python中List.count()方法的使用教程
2015/05/20 Python
对pandas的层次索引与取值的新方法详解
2018/11/06 Python
python编写微信公众号首图思路详解
2019/12/13 Python
Django如何在不停机的情况下创建索引
2020/08/02 Python
eDreams巴西:廉价机票,酒店优惠和度假套餐
2017/04/14 全球购物
英国领先的瓷砖专家:Walls and Floors
2018/04/27 全球购物
乌克兰设计师和品牌的服装:Love&Live
2020/04/14 全球购物
Servlet如何得到服务器的信息
2015/12/22 面试题
青年志愿者事迹材料
2014/02/07 职场文书
市级优秀班主任事迹材料
2014/05/13 职场文书
党员四风问题对照检查材料思想汇报
2014/09/16 职场文书
妈妈别哭观后感
2015/06/08 职场文书
2015年中学图书馆工作总结
2015/07/22 职场文书
2016年教师学习廉政准则心得体会
2016/01/20 职场文书
Python利用folium实现地图可视化
2021/05/23 Python
python基础学习之生成器与文件系统知识总结
2021/05/25 Python