在JavaScript中,什么相当于Java的Thread.sleep() ?


当前回答

试试这段代码。我希望这对你有用。

function sleep(seconds) 
{
  var e = new Date().getTime() + (seconds * 1000);
  while (new Date().getTime() <= e) {}
}

其他回答

你可以写一个自旋循环(一个循环,只是循环很长一段时间执行某种计算来延迟函数)或使用:

setTimeout("Func1()", 3000);

这将在3秒后调用'Func1()'。

编辑:

信用归评论者,但您可以将匿名函数传递给setTimeout。

setTimeout(function() {
   //Do some stuff here
}, 3000);

这样效率更高,而且不需要调用javascript的eval函数。

没有直接的对等物,因为它会暂停一个网页。但是有一个setTimeout(),例如:

function doSomething() {
  thing = thing + 1;
  setTimeout(doSomething, 500);
}

闭包例子(谢谢Daniel):

function doSomething(val) {
  thing = thing + 1;
  setTimeout(function() { doSomething(val) }, 500);
}

第二个参数是触发前的毫秒数,您可以将其用于时间事件或执行操作前的等待。

编辑:根据注释更新,以获得更清晰的结果。

假设你能够使用ECMAScript 2017,你可以通过使用async/await和setTimeout来模拟类似的行为。下面是一个睡眠函数的例子:

async function sleep(msec) {
    return new Promise(resolve => setTimeout(resolve, msec));
}

然后你可以在任何其他异步函数中使用sleep函数,就像这样:

async function testSleep() {
    console.log("Waiting for 1 second...");
    await sleep(1000);
    console.log("Waiting done."); // Called 1 second after the first console.log
}

这很好,因为它避免了需要回调。缺点是它只能在异步函数中使用。在后台,testSleep函数被暂停,在睡眠完成后,它将被恢复。

中数:

await表达式导致异步函数的执行暂停,直到 Promise被满足或拒绝,并恢复异步的执行 实现后的功能。

完整的解释见:

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/await

这最终帮助了我:

    var x = 0;
    var buttonText = 'LOADING';

    $('#startbutton').click(function(){
        $(this).text(buttonText);
        window.setTimeout(addDotToButton,2000);
    })

    function addDotToButton(){
        x++;
        buttonText += '.';
        $('#startbutton').text(buttonText);

        if (x < 4) window.setTimeout(addDotToButton, 2000);
        else location.reload(true);
    }

setTimeout不会在你自己的线程上保持和恢复。睡眠。在Javascript中没有真正的对等