ondurationchange 事件
当视频的时长发生变化时执行 JavaScript:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>蜜蜂教程(mifengjc.com)</title> </head> <body> <video controls ondurationchange="myFunction()"> <source src="/examples/mov_bbb.mp4" type="video/mp4"> <source src="/examples/mov_bbb.ogg" type="video/ogg"> 您的浏览器不支持 HTML5 video 元素。 </video> <script> function myFunction() { alert(" video 时长已修改"); } </script> </body> </html>
本文底部包含了更多实例。
定义和用法
ondurationchange 事件在视频/音频(audio/video)的时长发生变化时触发。
注意: 当视频/音频(audio/video)已经加载后,视频/音频(audio/video)的时长从 "NaN" 修改为正在的时长。
在视频/音频(audio/video)加载过程中,事件的触发顺序如下:
- onloadstart
- ondurationchange
- onloadedmetadata
- onloadeddata
- onprogress
- oncanplay
-
oncanplaythrough
浏览器支持
表格中的数字表示支持该事件的第一个浏览器的版本号。
事件 | |||||
---|---|---|---|---|---|
ondurationchange | Yes | 9.0 | Yes | Yes | Yes |
语法
HTML 中:
<element ondurationchange="myScript">
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>蜜蜂教程(mifengjc.com)</title> </head> <body> <p>该实例演示了如何向 video 元素添加 "ondurationchange" 事件。</p> <video controls ondurationchange="myFunction()"> <source src="/examples/mov_bbb.mp4" type="video/mp4"> <source src="/examples/mov_bbb.ogg" type="video/ogg"> 您的浏览器不支持 HTML5 video 元素。 </video> <script> function myFunction() { alert(" video 时长已修改"); } </script> </body> </html>
JavaScript 中:
object.ondurationchange = function() { myScript };
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>蜜蜂教程(mifengjc.com)</title> </head> <body> <p>该实例演示了如何使用 HTML DOM 向 video 元素添加 "ondurationchange" 事件。</p> <video controls id="myVideo"> <source src="/examples/mov_bbb.mp4" type="video/mp4"> <source src="/examples/mov_bbb.ogg" type="video/ogg"> 您的浏览器不支持 HTML5 video 元素。 </video> <script> document.getElementById("myVideo").ondurationchange = function() { myFunction() }; function myFunction() { alert(" video 时长已修改"); } </script> </body> </html>
JavaScript 中, 使用 addEventListener() 方法:
object.addEventListener("durationchange", myScript);
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>蜜蜂教程(mifengjc.com)</title> </head> <body> <p>该实例演示了如何使用 addEventListener() 方法向 video 元素添加 "ondurationchange" 事件。</p> <video controls id="myVideo"> <source src="/examples/mov_bbb.mp4" type="video/mp4"> <source src="/examples/mov_bbb.ogg" type="video/ogg"> 您的浏览器不支持 HTML5 video 元素。 </video> <script> document.getElementById("myVideo").addEventListener("durationchange", myFunction); function myFunction() { alert(" video 时长已修改"); } </script> </body> </html>
注意: Internet Explorer 8 及更早 IE 版本不支持 addEventListener() 方法。
技术细节
是否支持冒泡: | No |
---|---|
是否可以取消: | No |
事件类型: | Event |
支持的 HTML 标签: | <audio>, <video> |
更多实例
当音频开始加载时执行 JavaScript :
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>蜜蜂教程(mifengjc.com)</title> </head> <body> <audio controls ondurationchange="myFunction()"> <source src="/examples/horse.ogg" type="audio/ogg"> <source src="/examples/horse.mp3" type="audio/mpeg"> 您的浏览器不支持 audio 元素。 </audio> <script> function myFunction() { alert(" audio 时长已修改"); } </script> </body> </html>
事件对象