JavaScript sleep 实现

🌙
手机阅读
本文目录结构

sleep 使用场景

很多编程语言里都有 sleep(),delay() 等方法,

它能让我们的程序等待 N 秒后再进行后续的操作。

JavaScript 里有 setTimeout() 方法来实现设定一段时间后执行某个任务,但写法很丑陋,需要提供回调函数:

setTimeout(function(){
    //DO ...
}, 3000);

团队的一个测试小伙伴,会写 python,写 JS 代码的时候,想用 sleep 功能,不清楚怎么搞了;

我给他写了下面这个;

sleep 实现

(async function () {
    function sleep(time) {
        return new Promise((resolve) => setTimeout(resolve, time));
    }
    console.log(' --------- Start, ' + new Date());
    await sleep(1000 * 3);
    console.log(' --------- End, ' + new Date());
})();

sleep 说明

其中核心代码是下面这一点

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

这里需要提到的一个问题是,这个 sleep() 在执行的时候是“block”程序的继续执行的。

它不是同步的。如果想让它同步执行,不妨碍执行之后的代码,我们可以使用 async / await 关键字。

注意事项

因为使用了 asyncawait, 所以需要你的 Node.js 版本不低于 8.X

只有在 8.X 和后续版本,Nodejs 才迎接 async await 新时代,使用的时候一定要注意!!!

关键知识点

AXIHE / 精选教程

浏览全部教程

HTML

CSS

JS

书籍推荐