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 / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

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

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

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

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了