@baiwusanyu/utils-task
TypeScript icon, indicating that this package has built-in type declarations

1.1.2 • Public • Published

@baiwusanyu/utils-task

Type

ITask

任务队列实例

export interface ITask {
    // 任务函数
    fn: (...args: any[]) => any
    // 任务函数所需参数
    params: Array<any>
    // 重试次数,默认为0
    retry: number
    // 任务唯一id
    id: number
}

ITaskQueueHooks

任务队列执行钩子对象

export interface ITaskQueueHooks {
    // 所有任务执行完毕时钩子
    onFinished?: () => void
    // 任务执行成功时钩子
    onTaskSucceeded?: (index: number, task: ITask) => void
    // 任务执行失败时钩子
    onTaskFailed?: (index: number, task: ITask) => void
}

Function

setAsyncTaskList

生产一个异步任务列表

参数 参数类型 默认值 说明
taskNum Number - 异步任务数
taskFunc (index: number) => Promise<T> - 异步任务函数
返回值 返回类型 说明
taskList Promise<any>[] 任务执行列表

runAsyncTaskList

执行一个异步任务列表

参数 参数类型 默认值 说明
taskNum Number - 异步任务数
taskFunc (index: number) => Promise<Record<any, any> / void> - 异步任务函数
返回值 返回类型 说明
res Awaited<any>[] 执行结果列表

runTaskQueue

执行一个异步任务队列,它具有重试机制,当任务执行失败(报错),回重新添加到 队列末尾等待重新执行,一直到执行成功或达到该任务的最大执行次数。

参数 参数类型 默认值 说明
taskQueue Array<ITask> - 任务队列
hook ITaskQueueHooks - 任务队列执行钩子对象
maxRetry Number 5 最大重试数量
log Boolean true 是否打印日志
返回值 返回类型 说明
res {success:number[], fail: number[]} 执行结果列表,分别对应执行成功的任务或失败任务的id

Dependents (6)

Package Sidebar

Install

npm i @baiwusanyu/utils-task

Weekly Downloads

1,679

Version

1.1.2

License

MIT

Unpacked Size

11.6 kB

Total Files

6

Last publish

Collaborators

  • baiwusanyu