时间:2021-05-26
这篇文章主要讲一下如何串行执行一组异步任务,例如有下面几个任务,在这里我们用setTimeout模拟一个异步任务:
let taskA = () => setTimeout(() => console.log('runtaskA'), 100);let taskB = () => setTimeout(() => console.log('runtaskB'), 50);let taskC = () => setTimeout(() => console.log('runtaskC'), 150);直接运行
taskA(); taskB(); taskC();是达不到顺序执行A,B,C 的三个任务的效果的。
首先我们看一下最传统的做法,通过回调的方式在一个任务执行完成之后调用下一个任务:
let taskA = setTimeout(() => { console.log('runtaskA'); taskB();}, 100);let taskB = setTimeout(() => { console.log('runtaskB'); taskC();}, 50);let taskC = setTimeout(() => { console.log('runtaskB');}, 150);第二种方法是将每一个任务封装成一个返回Promise的函数, 然后使用使用Promise的链式调用达到串行执行的目的:
let taskA = () => new Promise((resolve, reject) => { setTimeout(() => { console.log('runtaskA'); resolve(); }, 100);})let taskB = () => new Promise((resolve, reject) => { setTimeout(() => { console.log('runtaskB'); resolve(); }, 50);})let taskC = () => new Promise((resolve, reject) => { setTimeout(() => { console.log('runtaskC'); resolve(); }, 150);})function runTasks2() { console.log('tasks2'); taskA().then(taskB).then(taskC);}假设任务的数量不确定,可以通过下面的方式来执行:
function runTasks3(tasks) { console.log('tasks3'); let pro = tasks[0](); for (let i = 1; i < tasks.length; i++) { pro.then(tasks[i]); }}借助于es7的async和await,我们还可以对上面的函数一种写法:
async function runTasks3_1(tasks) { for (let i = 0; i < tasks.length; i++) { await tasks[i](); }}在文章的最后我们自己来实现一个串行执行器, 用于执行一组串行任务:
function async(tasks) { const count = tasks.length; let index = 0; const next = () => { if (index >= count) return; const task = tasks[index++]; task(next); } next(0);}函数的使用方式如下:
async([ next => setTimeout(() => { console.log('taskA...'); next() }, 100), next => setTimeout(() => { console.log('taskB...'); next() }, 50), next => setTimeout(() => { console.log('taskC...'); next() }, 30) ]);在每一个子任务中我们通过调用next函数继续执行下一个子任务。
在具体的使用中可能会遇到函数之间传递参数的情况,即前一个任务的执行结果需要作为下一个任务的入参,这些都可以对上面的例子稍作修改就可以了~~
到此这篇关于Javascript异步流程控制之串行执行详解的文章就介绍到这了,更多相关Javascript串行执行内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
JavaScript数组JavaScript函数基础Javascript运算符JavaScript流程控制JavaScript正则表达式JavaScript字符
流程控制流程:代码执行的过程控制:对代码执行过程的把控三大结构顺序结构:代码默认从上到下,依次执行分支结构:单项分支,双向分支,多项分支,巢状分支循环结构:wh
Async的简单介绍:Async是一个流程控制工具包,提供了直接而强大的异步功能。基于Javascript为Node.js设计,同时也可以直接在浏览器中使用。A
微信小程序中使用Promise进行异步流程处理的实例详解我们知道,JavaScript是单进程执行的,同步操作会对程序的执行进行阻塞处理。比如在浏览器页面程序中
详解IOS串行队列与并行队列进行同步或者异步的实例IOS中GCD的队列分为串行队列和并行队列,任务分为同步任务和异步任务,他们的排列组合有四种情况,下面分析这四