我使用async。瀑布,我想做一些这样的:
保持异步的结果。通过返回Promise之类的东西来实现瀑布。这样我就可以把这两部分分开了
function Action1(){
return async.waterfall([
function step1(callback){
...
callback(null, data);
},
function step2(data, callback){
...
callback(null, data);
},
function step3(data, callback){
...
callback(null, data);
}
]);
}
Action1().then(function(result){
// obtain the final result here
});
然而,我发现的是:最终回调只能作为参数注入瀑布函数。
async.waterfall([
function(callback) {
...
callback(null, data);
},
function(data, callback) {
...
callback(null, data);
},
function(data, callback) {
...
callback(null, data);
}
], function (err, result) {
// final callback
...
});
有什么建议给我,以实现预期的编程结构?或者除了async之外还有其他选择吗?
你应该选择蓝鸟。
async
代码如下:
async.waterfall([
function(callback) {
callback(null, 'one', 'two');
},
function(arg1, arg2, callback) {
// arg1 now equals 'one' and arg2 now equals 'two'
callback(null, 'three');
},
function(arg1, callback) {
// arg1 now equals 'three'
callback(null, 'done');
}
], function (err, result) {
// result now equals 'done'
});
可以这样写(使用Blubird):
Promise.resolve(['one', 'two']).spread(function(arg1, arg2) {
// arg1 now equals 'one' and arg2 now equals 'two'
return 'three';
}).then(function(arg1) {
// arg1 now equals 'three'
return 'done';
}).then(function(result) {
// result now equals 'done'
});
您可以参考http://bluebirdjs.com/docs/coming-from-other-libraries.html#coming-from-async-module获取更多信息。