我正在尝试制作一个每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/