我有一个JavaScript代码,我需要添加一个睡眠/等待功能。我正在运行的代码已经在一个函数中,例如:

function myFunction(time)
{
    alert('time starts now');
    //code to make the program wait before continuing
    alert('time is up')
}

我听说一个可能的解决方案可能包括

setTimeout

但是我不知道在这种情况下如何使用它。

我不能使用PHP,因为我的服务器不支持它,尽管使用jQuery会很好。


当前回答

JS没有睡眠函数,它有setTimeout()或setInterval()函数。

如果你可以将暂停后需要运行的代码移动到setTimeout()回调中,你可以这样做:

//code before the pause
setTimeout(function(){
    //do what you need here
}, 2000);

参见示例:http://jsfiddle.net/9LZQp/

这不会停止脚本的执行,但由于setTimeout()是一个异步函数,因此此代码

console.log("HELLO");
setTimeout(function(){
    console.log("THIS IS");
}, 2000);
console.log("DOG");

将在控制台中打印:

HELLO
DOG
THIS IS

(注意在THIS is之前打印DOG)


你可以使用下面的代码来模拟短时间的睡眠:

function sleep(milliseconds) {
  var start = new Date().getTime();
  for (var i = 0; i < 1e7; i++) {
    if ((new Date().getTime() - start) > milliseconds){
      break;
    }
  }
}

现在,如果你想睡一秒钟,只需使用:

sleep(1000);

例如:http://jsfiddle.net/HrJku/1/

请注意,这段代码将使脚本忙碌n毫秒。这不仅会停止在页面上执行Javascript,而且根据浏览器的实现,可能会使页面完全无响应,甚至可能使整个浏览器无响应。换句话说,这几乎总是错误的做法。

其他回答

JS没有睡眠函数,它有setTimeout()或setInterval()函数。

如果你可以将暂停后需要运行的代码移动到setTimeout()回调中,你可以这样做:

//code before the pause
setTimeout(function(){
    //do what you need here
}, 2000);

参见示例:http://jsfiddle.net/9LZQp/

这不会停止脚本的执行,但由于setTimeout()是一个异步函数,因此此代码

console.log("HELLO");
setTimeout(function(){
    console.log("THIS IS");
}, 2000);
console.log("DOG");

将在控制台中打印:

HELLO
DOG
THIS IS

(注意在THIS is之前打印DOG)


你可以使用下面的代码来模拟短时间的睡眠:

function sleep(milliseconds) {
  var start = new Date().getTime();
  for (var i = 0; i < 1e7; i++) {
    if ((new Date().getTime() - start) > milliseconds){
      break;
    }
  }
}

现在,如果你想睡一秒钟,只需使用:

sleep(1000);

例如:http://jsfiddle.net/HrJku/1/

请注意,这段代码将使脚本忙碌n毫秒。这不仅会停止在页面上执行Javascript,而且根据浏览器的实现,可能会使页面完全无响应,甚至可能使整个浏览器无响应。换句话说,这几乎总是错误的做法。