扫码关注官方订阅号
:是否播放背景音乐
代码如上,想要做一个点击checkbox实现背景音乐淡入淡出的小功能,淡入可以实现,但是淡出时,我想要音量变为0时,自动暂停。但是我这个音量变为0之后,进度条仍然在走,m1.pause()没有生效。。
实在搞不明白,前端小白,求指导π-π
业精于勤,荒于嬉;行成于思,毁于随。
问题出在volume的值,在HTML5规范中,volume的值是不能小于0的,但你代码中的计算使volume的值小于0了,故脚本出错了不再执行。建议改成
if(m1.volume>0.1){ m1.volume-=0.1; }else{ clearInterval(timer); m1.pause(); }
这是错误记录:Failed to set the 'volume' property on 'HTMLMediaElement': The volume provided (1.1) is outside the range [0, 1]另外,代码没有通过连续点击测试,声音没达到最大时再点checkbox,会出现bug.
改成这样:
var timer = null; bgm.onchange=function(){ if(this.checked){ m1.volume=0; m1.play(); clearInterval(timer); timer=setInterval(function(){ m1.volume+=0.1; if(m1.volume>0.9){ clearInterval(timer); } },200); }else{ clearInterval(timer); timer=setInterval(function(){ console.log(m1.volume) if(m1.volume>0){ // m1.volume -= 0.1;这里会有精度问题,一直减0.1不是到从1到0 m1.volume = m1.volume-0.1<=0?0:m1.volume-0.1; }else{ m1.pause(); clearInterval(timer); } },200); } }`
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
问题出在volume的值,在HTML5规范中,volume的值是不能小于0的,但你代码中的计算使volume的值小于0了,故脚本出错了不再执行。建议改成
这是错误记录:
Failed to set the 'volume' property on 'HTMLMediaElement': The volume provided (1.1) is outside the range [0, 1]
另外,代码没有通过连续点击测试,声音没达到最大时再点checkbox,会出现bug.
改成这样: