小码哥的IT人生

onvolumechange 事件

JavaScript基础 2022-06-08 12:03:44小码哥的IT人生shichen

onvolumechange 事件

实例

当视频的音量改变时执行 JavaScript:

<video onvolumechange="myFunction()">

完整实例:

<!DOCTYPE html> 
<html> 
<body> 
<p>本例演示如何将 "onvolumechange" 事件分配给 video 元素。</p>
<p>请尝试更改右下角的音量。</p>
<video controls onvolumechange="myFunction()">
  <source src="/i/photo/shanghai.mp4" type="video/mp4">
  Your browser does not support HTML5 video.
</video>
<script>
function myFunction() {
  alert("The volume has been changed!");
}
</script>
</body> 
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

页面下方有更多 TIY 实例。

定义和用法

每次更改视频/音频的音量时都会发生 onvolumechange 事件。

此事件由以下情况触发:

  1. 增加或减少音量
  2. 将媒体播放器静音或取消静音

提示:请使用音频/视频对象的 volume 属性 来设置或返回音频/视频的音量。

浏览器支持

表中的数字注明了完全支持该事件的首个浏览器版本。

事件 Chrome IE Firefox Safari Opera
onvolumechange 支持 9.0 支持 支持 支持

语法

在 HTML 中:

<element onvolumechange="myScript">

完整实例:

<!DOCTYPE html> 
<html> 
<body> 
<p>本例演示如何将 "onvolumechange" 事件分配给 video 元素。</p>
<p>请尝试更改右下角的音量。</p>
<video controls onvolumechange="myFunction()">
  <source src="/i/photo/shanghai.mp4" type="video/mp4">
  Your browser does not support HTML5 video.
</video>
<script>
function myFunction() {
  alert("The volume has been changed!");
}
</script>
</body> 
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

在 JavaScript 中:

object.onvolumechange = function(){myScript};

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>本例使用 HTML DOM 将 "onvolumechange" 事件分配给 video 元素。</p>
<p>请尝试更改右下角的音量。</p>
<video controls id="myVideo">
  <source src="/i/photo/shanghai.mp4" type="video/mp4">
  Your browser does not support HTML5 video.
</video>
<script>
document.getElementById("myVideo").onvolumechange = function() {myFunction()};
function myFunction() {
  alert("The volume has been changed!");
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

在 JavaScript 中,使用 addEventListener() 方法:

object.addEventListener("volumechange", myScript);

完整实例:

<!DOCTYPE html>
<html>
<body>
<p>本例使用 addEventListener() 方法将 "volumechange" 事件附加到 video 元素。</p>
<p>请尝试更改右下角的音量。</p>
<video controls id="myVideo">
  <source src="/i/photo/shanghai.mp4" type="video/mp4">
  Your browser does not support HTML5 video.
</video>
<script>
document.getElementById("myVideo").addEventListener("volumechange", myFunction);
function myFunction() {
  alert("The volume has been changed!");
}
</script>
</body>
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

注释:Internet Explorer 8 或更早的版本不支持 addEventListener() 方法

技术细节

冒泡: 不支持
可取消: 不支持
事件类型: Event
支持的 HTML 标签: <audio><video>
DOM 版本: Level 3 Events

更多实例

示例代码:

当音频音量改变时执行 JavaScript:

<audio onvolumechange="myFunction()">

完整实例:

<!DOCTYPE html> 
<html> 
<body> 
<p>本例演示如何将 "onvolumechange" 事件分配给 audio 元素。</p>
<p>请尝试更改右下角的音量。</p>
<audio controls onvolumechange="myFunction()">
  <source src="/i/horse.ogg" type="audio/ogg">
  <source src="/i/horse.mp3" type="audio/mpeg">
  Your browser does not support the audio element.
</audio>
<script>
function myFunction() {
  alert("The volume has been changed!");
}
</script>
</body> 
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

示例代码:

使用 volume 属性设置音量:

document.getElementById("myVideo").volume = 0.2;

完整实例:

<!DOCTYPE html> 
<html> 
<body> 
<video id="myVideo" width="320" height="240" controls>
  <source src="/i/photo/shanghai.mp4" type="video/mp4">
  Your browser does not support the video tag.
</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 = "The audio volume is: " + x.volume;
} 
// 将音量设置为 0.2
function setHalfVolume() { 
  x.volume = 0.2;
} 
// 将音频音量设置为 1.0(最高)
function setFullVolume() { 
  x.volume = 1.0;
} 
</script> 
</body> 
</html>

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

版权所有 © 小码哥的IT人生
Copyright © phpcodeweb All Rights Reserved
ICP备案号:苏ICP备17019232号-2  

苏公网安备 32030202000762号

© 2021-2024