作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何检测视频静音和循环属性的切换?
不幸的是,没有“onmuted”或“onloop”事件,如“onplay”或“onpause”。
Object.observe 不起作用。
MutationObserver 也不起作用。
如有任何建议,我们将不胜感激。
最佳答案
1) 您可以使用“volumechange”事件检测muted
。
video.addEventListener('volumechange', function () {
console.log('muted', video.muted);
}, false);
// video.onvolumechange = ... works too
2) MutationObserver 不能静音工作,因为它没有属性,但它确实适用于loop
。
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
if (mutation.type === 'attribute' && mutation.attributeName === 'loop') {
console.log('loop changed', video.loop);
}
});
});
observer.observe(video, {
attributes: true
});
在我的测试中,无论您是使用 Javascript(至少在 Chrome 和 Firefox 中)还是使用右键单击下拉菜单(在 FF 中不可用,只是 Chrome)在视频元素上。
关于javascript - HTML5 视频 - onmuted 和 onloop 事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25105414/
如何检测视频静音和循环属性的切换? 不幸的是,没有“onmuted”或“onloop”事件,如“onplay”或“onpause”。 Object.observe 不起作用。 MutationObse
我是一名优秀的程序员,十分优秀!