HTML Audio/Video DOM timeupdate 事件
当视频播放位置已经改变,显示视频当前播放位置(一秒计):
<p>该实例中,我们使用了 HTML DOM 为 video 元素添加 "ontimeupdate" 事件。 在用户开始播放视频,或者移动视频的播放位置时触发函数,并显示视频的播放位置。
</p>
<video id="myVideo" width="320" height="176" controls>
<source src="/examples/mov_bbb.mp4" type="video/mp4">
<source src="/examples/mov_bbb.ogg" type="video/ogg">
您的浏览器不支持 HTML5 video 标签。
</video>
<p>播放位置: <span id="demo"></span></p>
<script>
// 获取 id="myVideo" 的 video 元
var vid = document.getElementById("myVideo");
// 为 video 元素添加 ontimeupdate 事件,如果当前播放位置改变则执行函数
vid.ontimeupdate = function() {
myFunction()
};
function myFunction() {
// 显示 id="demo" 的 p 元素中视频的播放位置
document.getElementById("demo").innerHTML = vid.currentTime;
}
</script>
本文底部包含了更多实例。
定义和用法
timeupdate 事件在音频/视频(audio/video)的播放位置发生改变时触发。
该事件可以在以下情况被调用:
- 播放音频/视频(audio/video)
- 移动音频/视频(audio/video)播放位置
提示: timeupdate 事件通常与 Audio/Video 对象的 currentTime 属性一起使用,该属性返回音频/视频(audio/video)的播放位置(以秒计)。
浏览器支持
表格中的数字表示支持该事件的第一个浏览器的版本号。
事件 | |||||
---|---|---|---|---|---|
timeupdate | Yes | 9.0 | Yes | Yes | Yes |
语法
HTML 中:
<audio|video ontimeupdate="myScript">
<p>该实例中,我们为 video 元素添加 "ontimeupdate" 事件。 在用户开始播放视频,或者移动视频的播放位置时触发函数,并显示视频的播放位置。
</p>
<video controls ontimeupdate="myFunction(this)">
<source src="/examples/mov_bbb.mp4" type="video/mp4">
<source src="/examples/mov_bbb.ogg" type="video/ogg">
您的浏览器不支持 HTML5 video 标签。
</video>
<p>播放位置: <span id="demo"></span></p>
<script>
function myFunction(event) {
// currentTime 属性返回音频/视频(audio/video)的播放位置
document.getElementById("demo").innerHTML = event.currentTime;
}
</script>
JavaScript 中:
audio | video.ontimeupdate = function() {
myScript
};
<p>该实例中,我们使用了 HTML DOM 为 video 元素添加 "ontimeupdate" 事件。 在用户开始播放视频,或者移动视频的播放位置时触发函数,并显示视频的播放位置。
</p>
<video id="myVideo" width="320" height="176" controls>
<source src="/examples/mov_bbb.mp4" type="video/mp4">
<source src="/examples/mov_bbb.ogg" type="video/ogg">
您的浏览器不支持 HTML5 video 标签。
</video>
<p>播放位置: <span id="demo"></span></p>
<script>
// 获取 id="myVideo" 的 video 元
var vid = document.getElementById("myVideo");
// 为 video 元素添加 ontimeupdate 事件,如果当前播放位置改变则执行函数
vid.ontimeupdate = function() {
myFunction()
};
function myFunction() {
// 显示 id="demo" 的 p 元素中视频的播放位置
document.getElementById("demo").innerHTML = vid.currentTime;
}
</script>
JavaScript 中, 使用 addEventListener() 方法:
audio | video.addEventListener("timeupdate", myScript);
<p>该实例中,我们使用了 addEventListener() 方法为 video 元素添加 "ontimeupdate" 事件。 在用户开始播放视频,或者移动视频的播放位置时触发函数,并显示视频的播放位置。
</p>
<video id="myVideo" controls>
<source src="/examples/mov_bbb.mp4" type="video/mp4">
<source src="/examples/mov_bbb.ogg" type="video/ogg">
您的浏览器不支持 HTML5 video 标签
</video>
<p>播放位置: <span id="demo"></span></p>
<script>
// 获取 id="myVideo" 的 video 元
var vid = document.getElementById("myVideo");
// 为 video 元素添加 ontimeupdate 事件,如果当前播放位置改变则执行函数
vid.addEventListener("timeupdate", myFunction);
function myFunction() {
// 显示 id="demo" 的 p 元素中视频的播放位置
document.getElementById("demo").innerHTML = vid.currentTime;
}
</script>
注意: Internet Explorer 8 及更早 IE 版本不支持 addEventListener() 方法。
技术细节
支持的 HTML 标签: | <audio> 和 <video> |
---|---|
支持的 JavaScript 对象: | Audio, Video |
更多实例
当音频的播放位置改变时,显示当前音频的播放位置(以秒计):
<p>该实例中,我们使用了 HTML DOM 为 audio 元素添加 "ontimeupdate" 事件。 在用户开始播放视频,或者移动音频的播放位置时触发函数,并显示视频的播放位置。
</p>
<audio id="myAudio" controls>
<source src="/examples/horse.ogg" type="audio/ogg">
<source src="/examples/horse.mp3" type="audio/mpeg">
您的浏览器不支持 audio 元素。
</audio>
<p>播放位置: <span id="demo"></span></p>
<script>
// 获取 id="myAudio" 的 audio
var aud = document.getElementById("myAudio");
// 为 audio 元素添加 ontimeupdate 事件,并在播放位置改变时执行函数
aud.ontimeupdate = function() {
myFunction()
};
function myFunction() {
// 显示 id="demo" 的 <p> 元素中音频的播放位置
document.getElementById("demo").innerHTML = aud.currentTime;
}
</script>
使用 currentTime 属性设置播放位置为 5 秒:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>蜜蜂教程(mifengjc.com)</title>
</head>
<body>
<video id="myVideo" width="320" height="240" controls>
<source src="/examples/movie.mp4" type="video/mp4">
<source src="/examples/movie.ogg" type="video/ogg">
Your browser does not support the video tag.
</video><br>
<button onclick="setCurTime()" type="button">设置播放位置为 5 秒</button>
<p id="demo"></p>
<script>
// 获取 id="myVideo" 的 video 元
var vid = document.getElementById("myVideo");
// 为 video 添加 "timeupdate" 事件
vid.addEventListener("timeupdate", getCurTime);
// 显示 id="demo" 的 p 元素中视频的播放位置
function getCurTime() {
document.getElementById("demo").innerHTML = "当前播放位置为 " + vid.currentTime + " 秒。";
}
// 设置播放位置为 5 秒
function setCurTime() {
vid.currentTime = 5;
}
</script>
</body>
</html>
