Skip to main content

强大的async.auto!

强大的async.auto!

以前在阅读Async JavaScript Build More Responsive Apps with Less Code一书的时候,认识了Async库!开始的时候,没有体会async的魅力,直到最近用NodeJs写网站的时候,才发现,如果不用async,写出来的代码简直没法看。所以在中后期,我大量使用了Parallel和waterfull,但是写出来的代码仍旧比较凌乱,最近才发现async的一个强大的API,async.auto!我觉得,这个才是async的强大之处!

很多时候,你逻辑里面,既有waterfull的也有parallel的,那个就要写至少2个async函数调用,复杂的情况下,可能更多,但是async.auto的强大是在于,你定义好相互之间的dependencies,他来帮你决定用parallel还是waterfull。

看一个例子:

    async.auto({
func1: function (callback, results) {
callback(null, "abc", "bbc");
},

func2: function (callback, results) {
console.log("Print#1:\n" + util.inspect(results));
callback(null, { "puncha": "during" });
},
func3: ["func2", function (callback, results) {
console.log("Print#2:\n" + util.inspect(results));
callback(null, 3);
}],
func4: ["func1", "func3", function (callback, results) {
console.log("Print#3:\n" + util.inspect(results));
callback(null);
}]
});

async.auto接受一个对象,即键值对,其每一个属性,就是一个你要执行的函数逻辑,而依赖关系通过属性名指定。上面代码的意思是,func1和func2相互独立,没有依赖,func3依赖于func2,func4依赖于func1,func3(其实也间接依赖于func2)。那么,根据人脑判断,func1和func2可以并行执行,func3可以和func1并行但是需要等待func2,func4最后执行。如果不用async.auto的话,差不多这样吧:

    async.parallel([
func1,
async.waterfall([
func2,
func3
]),
], func4)

相比之下,async.auto代码更加简洁,而且将来要多加一个dependency也简单。另外async.auto还有一个特色,就是每一个callback都会传入一个results参数,让你得到你每个函数执行的结果(当然,如果你执行的之后,那个函数还没执行,就不会有结果),你不用自己显式地把结果存入results对象,async.auto会帮你做这件事情。上面那段代码执行的结果是:

Print#1:
{ func1: [ 'abc', 'bbc' ] }
Print#2:
{ func1: [ 'abc', 'bbc' ], func2: { puncha: 'during' } }
Print#3:
{ func1: [ 'abc', 'bbc' ],
func2: { puncha: 'during' },
func3: 3 }

首先,你调用callback,传入2个result,async.auto帮你变成了一个数组,func1: ['abc', 'bbc']

其次,func2的结果自动放入了results里面,func2: {puncha: 'during'}

这个应该能满足大部分需求了!