sleep函数作用是让线程休眠,等到指定时间在重新唤起。
方法一:这种实现方式是利用一个伪死循环阻塞主线程。因为JS是单线程的。所以通过这种方式可以实现真正意义上的sleep()。
function sleep(delay) {
var start = (new Date()).getTime();
while ((new Date()).getTime() - start < delay) {
continue;
}
}
function test() {
console.log('111');
sleep(2000);
console.log('222');
}
test()
方法二:定时器
function sleep1(ms, callback) {
setTimeout(callback, ms)
}
//sleep 1s
sleep1(1000, () => {
console.log(1000)
})
方法三:es6异步处理
const sleep = time => {
return new Promise(resolve => setTimeout(resolve,time)
) }
sleep(1000).then(()=>{ console.log(1) })
方法四:yield后面是一个生成器 generator
function sleepGenerator(time) {
yield new Promise(function(resolve,reject){
setTimeout(resolve,time);
})
}
sleepGenerator(1000).next().value.then(()=>{console.log(1)})
方法五:es7---- async/await是基于Promise的,是进一步的一种优化
function sleep(time) {
return new Promise(resolve =>
setTimeout(resolve,time)
) } async function output() {
let out = await sleep(1000);
console.log(1);
return out;
}
output();
注意点:
async
用来申明里面包裹的内容可以进行同步的方式执行,await
则是进行执行顺序控制,每次执行一个await
,程序都会暂停等待await
返回值,然后再执行之后的await
。
await
后面调用的函数需要返回一个promise,另外这个函数是一个普通的函数即可,而不是generator
。
await
只能用在async
函数之中,用在普通函数中会报错。
await
命令后面的 Promise
对象,运行结果可能是 rejected
,所以最好把 await
命令放在 try…catch
代码块中。
其实,async / await
的用法和co差不多,await
和yield
都是表示暂停,外面包裹一层async
或者 co来表示里面的代码可以采用同步的方式进行处理。不过async / await
里面的await
后面跟着的函数不需要额外处理,co是需要将它写成一个generator
的。