// 定义一个异步函数
const sleep = time=> new Promise(resolve=> setTimeout(()=> resolve('ok'), time))
const arr = [1, 2, 3]
const time = 1000
// 使用Promise.all()接收所有的异步函数处理结果
;(async ()=> {
console.time('test1')
console.log(1)
const arr2 = await Promise.all(arr.map(async item=> await sleep(time)))
console.log(arr2)
console.log(2)
console.timeEnd('test1')
// 总输出时间是1秒多
})()
;(async ()=> {
console.time('test2')
console.log(1)
const arr3 = []
for(let i = 0; i < arr.length; i++) {
arr3.push(await sleep(time))
}
console.log(arr3)
console.log(2)
console.timeEnd('test2')
//输出时间是3秒多
})()
map,each迭代函数中的async await用法(同时可以同时并行执行多个异步缩短时间)
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 使用 async-await 等待异步操作完成的时候,如果前后两个异步操作不存在依赖关系,同时触发应该是更好的方案...
- 本文主要讲两个方面的东西,一个是迭代方面,对应是生成器,语法是yield。另一个方面是异步编程,对应是协程,语...
- 1、先说一下async的用法,它作为一个关键字放到函数前面,用于表示函数是一个异步函数,因为async就是异步的意...