由於nodejs是異步處理的,有時我們想同步從mysql里取出數據,最后在處理邏輯 就需要用到此擴展;
此擴展可以避免多層回調;
安裝方法:
npm install async
使用方法:
1、parallel 多個函數並行執行
1 var Async = require('async'); 2 3 Async.parallel( 4 [ 5 function(callback){ 6 // 此處查詢數據庫代碼 7 DaoUser.getUserByID(userId, function(err, user) { 8 callback(err, user); 9 }); 10 }, 11 function(callback){ 12 // 此處查詢數據庫代碼 13 DaoUser.getTotal(callback, function(err, count){ 14 callback(err, count); 15 }); 16 } 17 // 如果還需要查詢數據 繼續添加方法即可 18 ], 19 function(err, results){ 20 var user = results[0]; 21 var count = results[1]; 22 } 23 );
2、waterfall 多個方法依次執行,前一個函數的返回值可以傳遞給下一個函數
1 var Async = require('async'); 2 3 Async.waterfall([ 4 function(callback) { 5 DaoUser.getUserIdByName(uName, function(err, userId) { 6 callback(null, userId); 7 }); 8 }, 9 function(userId, callback) { 10 DaoTask.getDateByUid(userId, function(err, tasks) { 11 callback(null, tasks); 12 }); 13 } 14 ], function(err, result) { 15 var tasks = result; 16 });
3、map 遍歷數組的值,執行結果傳給最后的callback
var Async = require('async'); var array = [1,2,3,4]; Async.map(array, function(data, callback) { data ++; callback(null, data); }, function(err, results) { console.log(results); } );
// 結果 [ 2, 3, 4, 5 ]