for循环中的setTimeout()的clearTimeout()

时间:2014-08-14 15:28:18

标签: javascript jquery settimeout cleartimeout

clearTimeout()圈内的

for无效

for(i=0;i<10;i++){
    myVar = setTimeout(function(){
        alert("Hello")
    }, 3000);
}

小提琴:not working

小提琴:working

请帮我在第一小提琴中停止setTimeout()

1 个答案:

答案 0 :(得分:8)

您必须保留对循环中创建的每个超时的引用,然后迭代并清除每个超时,否则您只需用新的超时覆盖myVar而不清除在前一个,并且随着你去掉手柄等等。

$(document).ready(function(){
    var myVar = []

    $("#myfunction").click(myFunction);
    $("#mystopfunction").click(myStopFunction);

    function myFunction() {
        for(i=0;i<10;i++){
            myVar.push(
                setTimeout(function(){
                    alert("Hello")
                }, 3000)
            );
        }
    }

    function myStopFunction() {
        myVar.forEach(function(timer) {
            clearTimeout(timer);
        });
    }
});

FIDDLE