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

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

如果你加我的私人微信,麻烦写上您的 称呼,所在地区,职业,方便我备注,谢谢


本站的微信公众号

阿西河前端教程

Anbang

安邦的私人微信

微信号: yaolushan

Anbang

Bilibili(B站)

朱安邦

Anbang