假设我使用Node.js尝试运行两个异步调用来获得一些答案。我知道有一个异步包,你可以在其中传递两个函数和一个可选的回调函数。
async.parallel([fun1(){callback(null,1);},
fun2(){callback(null,2);}],
function(err, results) {
});
但是假设我现在有一个优先级,如果fun1返回一个值,那么我不需要fun2的答案,只有当fun1返回null时,我才等待fun2。所以我不想使用回调函数,因为回调等待两个函数完成,而fun2可能需要很长时间。
现在我只是通过为异步调用创建回调函数来使用非常详尽的方法。
function(){
var theAnswer,FromFun1,FromFun2;
var reply1,reply2;
fun1(reply1="answered";FromFun1=1;complete());
fun2(reply2="answered";FromFun2=2;complete());
function complete(answer){
if(reply1=="answered"){
theAnswer=FromFun1;
}else if(reply1==null){
// Don't do anything because fun1 is not finished running.
}else if(reply2=="answered"){
theAnswer=FromFun2;
}else{
// Both have no answer, err.
}
}
}
有更好的方法吗?
答案 0 :(得分:2)
最好使用瀑布而不是并行执行,因为你可以将前一个函数的结果作为参数传递给下一个函数。
async.waterfall([
function(callback){
callback(null, 'one');
},
function(arg1, callback){
// arg1 now equals 'one'
if(arg1==null){
// it will not take time it returns immediately
callback(null, 'done');
}else{
// do your another stuff here fun2 logic here
// it will not be executed and so it dont take time
}
}
], function (err, result) {
// result now equals 'done'
});
答案 1 :(得分:2)
我在这个场景中使用的技巧是在回调的第一个参数中返回“done”:
async.parallel([
function(callback){
callback("done",1);
},
function(callback){
callback(null,2);
}
], function(err, results) {
console.log(err, results); // done [ 1 ] or done [ 1 , 2 ]
});
听起来像是一个黑客,我通常不会这样做,但在一些罕见的情况下,如此,它实际上保持代码清洁...只是记录它,以便其他人知道你的意图。