nodejs中解决异步嵌套循环和循环嵌套异步的问题
众所周知,nodejs异步和循环对于初学者来说是一个很大的问题,今天我们就一起来了解和解决它
当异步和循环同时出现的时候这个问题就会被放大很多倍.
庆幸的是,大神们研究出了async这个第三方模块,解决了node中异步金字塔和循环问题
async这个模块应该是nodejs中使用最多的第三方模块,每个月下载量3000w+
async基础使用 :
异步嵌套循环,循环嵌套异步的例子:
var async = require('async'); //初始化 var async_lists = [{ aa: 11, bb: 21 }, { aa: 31, bb: 41 }, { aa: 51, bb: 61 }, { aa: 71, bb: 81 }, { aa: 91, bb: 91 }]; var task = []; task.push(function (callback) { console.log('第一个task任务'); //循环 async.eachseries(async_lists, function (async_list, cb) { task_a(async_list, cb) }, function (err) { if (err) return callback(err); //重新赋值 async_lists = [{ aa: 12, bb: 22 }, { aa: 32, bb: 42 }, { aa: 52, bb: 62 }, { aa: 72, bb: 82 }, { aa: 92, bb: 92 }]; callback() }); }) task.push(function (callback) { console.log('第二个task任务'); async.eachseries(async_lists, function (async_list, cb) { task_a(async_list, cb) }, function (err) { if (err) return callback(err); async_lists = [{ aa: 13, bb: 23 }, { aa: 33, bb: 43 }, { aa: 53, bb: 63 }, { aa: 73, bb: 83 }, { aa: 93, bb: 93 }]; callback() }); }) task.push(function (callback) { console.log('第三个task任务'); async.eachseries(async_lists, function (async_list, cb) { task_a(async_list, cb) }, function (err) { if (err) return callback(err); callback() }); }) //最外层流程控制 async.waterfall(task, function (err, result) { if (err) return console.log(err); console.log('成功'); }) function task_a(async_list, cb) { var task2 = []; task2.push(function (cb) { console.log('第一次 : ', async_list); settimeout(function () { cb() }, 1000); }) task2.push(function (cb) { console.log('第二次 : ', async_list); console.log('---------------------------'); settimeout(function () { cb() }, 1000); }) //循环内流程控制 async.waterfall(task2, function (err, result) { if (err) return cb(err); cb(); }) }
解释下这个例子:
首先,最外层使用了async.waterfall这个方法控制task数组里的异步任务执行顺序,一共push了3个任务async.waterfall(task, function (err, result) {},每执行完一次task里的任务,重新对async_lists赋值;
然后,每一个task任务里都有一个同样的循环,循环async_lists这个数组里的每一个对象,使用async.eachseries控制必须循环里所有任务执行完毕才往下执行;
最后,在eachseries循环里又有一个异步task2任务,这个任务分2步,分别打印了传入进来的async_list的值,而且每次打印都使用settimeout暂停一秒才执行下一个任务.
预期的结果是 : 首先执行task里的第一个任务,分别打印2次async_lists这个数组里的每个对象,而且每次打印间隔一秒,然后对async_lists重新赋值,执行task里的第二个任务,重复以上操作.3次完成后打印 成功,结束任务.
输出的结果也是预期的结果.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: jQuery选择器特殊字符与属性空格问题
下一篇: js分页之前端代码实现和请求处理
推荐阅读
-
es7学习教程之fetch解决异步嵌套问题的方法示例
-
JavaScript的for循环中嵌套一个点击事件的问题解决
-
解决ASP.NET MVC返回的JsonResult 中 日期类型数据格式问题,和返回的属性名称转为“驼峰命名法”和循环引用问题
-
nodejs中解决异步嵌套循环和循环嵌套异步的问题
-
循环中嵌套异步操作的流程控制
-
Android解决ScrollView下嵌套ListView和GridView中内容显示不全的问题
-
用Promise解决多个异步Ajax请求导致的代码嵌套问题(完美解决方案)
-
详解JavaScript的for循环中嵌套一个点击事件的问题解决方法
-
es7学习教程之fetch解决异步嵌套问题的方法示例
-
解决ASP.NET MVC返回的JsonResult 中 日期类型数据格式问题,和返回的属性名称转为“驼峰命名法”和循环引用问题