我正在尝试制作一个每5秒移动一次的进度条。
这是我的代码:

function Progress(runner, validlinks)
{
    if (runner <= validlinks)
    {
        var myString = document.getElementById('links').value;
        var mySplit = myString.split("\n");
        var ValidLinksCount = 0;

        for(i = 0; i < mySplit.length; i++)
        {
            if (mySplit[i].search("who") != -1)
                ValidLinksCount++;
                ValidLinksCount++;
            else if (mySplit[i].search("we") != -1)
                ValidLinksCount++;
        }
        var jump = Math.ceil(100 / ValidLinksCount);
        runner++;
        document.getElementById("progressDiv").style.width = parseInt(document.getElementById("progressDiv").style.width) + jump + "%";
        window.setTimeout(Progress(runner,ValidLinksCount), 5000);
    }
}

我这样称呼按钮提交:
<input type="submit" name="submit" disabled="true" onclick="Progress(0,0);" value="check" />

它只是运行而不会等到下一次运行5秒钟,为什么?谢谢。

最佳答案

传递而不调用函数。

window.setTimeout(function() {
    Progress(runner,ValidLinksCount);
}, 5000);

关于javascript - javascript setTimeout错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8552747/

10-11 20:19