主题
parallel
并行运行多个异步函数
基本用法
类似 _.map
,但专门为并行运行异步回调函数而构建。第一个参数是一次允许运行的函数数量限制。返回结果数组。
ts
import { parallel } from 'radash'
const userIds = [1, 2, 3, 4, 5, 6, 7, 8, 9]
// 将同时运行3个查找用户的异步函数
// 当其中一个完成时,开始另一个请求
const users = await parallel(3, userIds, async (userId) => {
return await api.users.find(userId)
})
错误处理
当所有工作完成时,parallel将检查错误。如果发生任何错误,它们将全部在一个 AggregateError
中抛出,该错误具有一个 errors
属性,包含所有被抛出的错误。
ts
import { parallel, try as tryit } from 'radash'
const userIds = [1, 2, 3]
const [err, users] = await tryit(parallel)(3, userIds, async (userId) => {
throw new Error(`No, I don\'t want to find user ${userId}`)
})
console.log(err) // => AggregateError
console.log(err.errors) // => [Error, Error, Error]
console.log(err.errors[1].message) // => No, I don't want to find user 2