在onclick上播放/暂停,但只有一次?

时间:2015-02-26 12:19:22

标签: javascript html audio onclick

以下代码播放和停止音频文件,但只播放一次。 (1次播放,1次暂停)。有没有办法定期播放/暂停?

function audioHandler(){
 var audio = document.getElementById("myaudio"); 
 if(status == false){
 audio.style.display="block";
 audio.play();
 status = true;
 }
 else {
 audio.style.display="none";
 audio.pause();
 status = false;
 }
}

这不重要,但我也希望将游戏更改为暂停图标并向后...

<a href="#" onclick="audioHandler()"><img src="play.png"></a>

1 个答案:

答案 0 :(得分:1)

问题是全局变量status,因为您将它用作全局变量(窗口对象具有名为status的属性),分配给它的值将转换为字符串。

因此,当您应用status = false时,分配的实际值将为status = 'false';,这将始终是真实的,即'false' == false将为false,因此您的if块永远不会获得再次执行!!!

所以只需将变量status重命名为其他内容,然后就可以了

var aStatus = false;
function audioHandler() {
    var audio = document.getElementById("myaudio");
    var audioimg = document.getElementById("myaudioimg");
    if (aStatus == false) {
        audio.style.display = "block";
        audio.play();
        aStatus = true;
        audioimg.src = "pause.png"
    } else {
        audio.style.display = "none";
        audio.pause();
        aStatus = false;
        audioimg.src = "play.png"
    }
}

然后

<a href="#" onclick="audioHandler()"><img id="myaudioimg" src="play.png" /></a>