有关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动画效果
Aug 14 HTML / CSS
一款基于css3的列表toggle特效实例教程
Jan 04 HTML / CSS
浅谈css3中calc在less编译时被计算的解决办法
Dec 04 HTML / CSS
CSS3 创建网页动画实现弹跳球动效果
Oct 30 HTML / CSS
在html5的Canvas上绘制椭圆的几种方法总结
Jan 07 HTML / CSS
html5跨域通讯之postMessage的用法总结
Nov 07 HTML / CSS
html5定位获取当前位置并在百度地图上显示
Aug 22 HTML / CSS
使用phonegap进行本地存储的实现方法
Mar 31 HTML / CSS
手机端用rem+scss做适配的详解
Nov 15 HTML / CSS
html5 video全屏播放/自动播放的实现示例
Aug 06 HTML / CSS
Canvas实现放大镜效果完整案例分析(附代码)
Nov 26 HTML / CSS
CSS3实现列表无限滚动/轮播效果
Jun 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数组函数序列之array_slice() - 在数组中根据条件取出一段值,并返回
2011/11/07 PHP
基于Jquery的表格隔行换色,移动换色,点击换色插件
2010/12/22 Javascript
火狐下table中创建form导致两个table之间出现空白
2013/09/02 Javascript
解析JSON对象与字符串之间的相互转换
2013/12/18 Javascript
Eclipse去除js(JavaScript)验证错误
2014/02/11 Javascript
jQuery实现下拉框功能实例代码
2016/05/06 Javascript
jquery mobile界面数据刷新的实现方法
2016/05/28 Javascript
canvas雪花效果核心代码分享
2017/02/19 Javascript
Bootstrap实现各种进度条样式详解
2017/04/13 Javascript
详解ElementUI之表单验证、数据绑定、路由跳转
2017/06/21 Javascript
Vue组件中slot的用法
2018/01/30 Javascript
Vue自定义指令实现checkbox全选功能的方法
2018/02/28 Javascript
基于JavaScript实现单例模式
2019/10/30 Javascript
Element的el-tree控件后台数据结构的生成以及方法的抽取
2020/03/05 Javascript
用jQuery实现抽奖程序
2020/04/12 jQuery
python实现倒计时的示例
2014/02/14 Python
python+Django+apache的配置方法详解
2016/06/01 Python
玩转python selenium鼠标键盘操作(ActionChains)
2020/04/12 Python
django使用图片延时加载引起后台404错误
2017/04/18 Python
使用C++扩展Python的功能详解
2018/01/12 Python
Python模块搜索路径代码详解
2018/01/29 Python
python实现雨滴下落到地面效果
2018/06/21 Python
Python画图实现同一结点多个柱状图的示例
2019/07/07 Python
Django模板导入母版继承和自定义返回Html片段过程解析
2019/09/18 Python
Python Celery多队列配置代码实例
2019/11/22 Python
django 链接多个数据库 并使用原生sql实现
2020/03/28 Python
Python动态导入模块:__import__、importlib、动态导入的使用场景实例分析
2020/03/30 Python
Smashbox英国官网:美国知名彩妆品牌
2017/11/13 全球购物
linux面试题参考答案(8)
2016/04/19 面试题
学校安全生产月活动总结
2014/07/05 职场文书
呼兰河传读书笔记
2015/06/30 职场文书
护士业务学习心得体会
2016/01/25 职场文书
JavaScript阻止事件冒泡的方法
2021/12/06 Javascript
VUE中的v-if与v-show区别介绍
2022/03/13 Vue.js
python中 Flask Web 表单的使用方法
2022/05/20 Python
前端框架ECharts dataset对数据可视化的高级管理
2022/12/24 Javascript