定义和用法
onvolumechange 事件在视频/音频(audio/video)的音量发生改变时触发。
该事件可以通过以下方式调用:
- 增大或降低音量
- 媒体播放器静音或解除静音
提示: 使用 Audio 或 Video 对象的 volume 属性来设置或返回视频/音频(audio/video)的音量。
浏览器支持
表格中的数字表示支持该事件的第一个浏览器的版本号。
事件 | 谷歌 | IE | 火狐 | 苹果 | opera |
---|---|---|---|---|---|
onvolumechange | Yes | 9.0 | Yes | Yes | Yes |
语法
HTML 中:
<element onvolumechange="myScript">
JavaScript 中:
object.onvolumechange=function(){myScript};
JavaScript 中, 使用 addEventListener() 方法:
object.addEventListener("volumechange", myScript);
注意: Internet Explorer 8 及更早 IE 版本不支持 addEventListener() 方法。
技术细节
是否支持冒泡: | No |
---|---|
是否可以取消: | No |
事件类型: | Event |
支持的 HTML 标签: | <audio>, <video> |
实例
当音频的音量改变时执行 JavaScript:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Web176教程(web176.com)</title> </head> <body> <p>该实例演示了如何向 audio 元素添加 "onvolumechange" 事件。</p> <p>点击右边的音量按钮调整音量。</p> <audio controls onvolumechange="myFunction()"> <source src="bbb.ogg" type="audio/ogg"> <source src="bbb.mp3" type="audio/mpeg"> 您的浏览器不支持 audio 元素。 </audio> <script> function myFunction() { alert("音量已改变!"); } </script> </body> </html>
使用 volume 属性设置音量:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Web176教程(web176.com)</title> </head> <body> <video id="myVideo" width="320" height="240" controls> <source src="bbb.mp4" type="video/mp4"> <source src="bbb.ogg" type="video/ogg"> 您的浏览器不支持 HTML5 video。 </video> <p>点击以下按钮修改音量值,或者点击右边的音量按钮来调整音量。</p> <button onclick="setHalfVolume()" type="button">设置音量为 0.2</button> <button onclick="setFullVolume()" type="button"设置音量为 1.0</button> <p id="demo"></p> <script> // 获取 id="myVideo" 的 video 元素 var x = document.getElementById("myVideo"); // 向视频添加 "volumechange" 事件 x.addEventListener("volumechange", getVolume); // 显示 id="demo" 的 p 元素中视频的音量 function getVolume() { document.getElementById("demo").innerHTML = "视频音量为: " + x.volume; } // 设置音量为 0.2 function setHalfVolume() { x.volume = 0.2; } // 设置音量为 1.0 (最大) function setFullVolume() { x.volume = 1.0; } </script> </body> </html>
作者:terry,如若转载,请注明出处:https://www.web176.com/javascriptbook/domtips/4159.html