我使用q.js来处理异步调用的问题情况。可能是我对promise的理解不到位,对于reject()的情况我一直觉得处理起来很别扭。先来看下我的处理方式,有不妥之处,欢迎予以指出。
代码如下:
var Q = require('q');
Q.fcall(function(){
return 2;
}).then(function(v){//f1
var deferred = Q.defer();
if(v == 1)
deferred.resolve("resolve");
else
deferred.reject("reject");
return deferred.promise;
}).then(function(){//f2
console.log("f2 resolve");
},function(){
console.log("f2 reject");
//如果上一函数是reject走到这里,由于函数已报错,我不希望再执行f3函数,这里改怎么写能不让f3执行呢?
//正常的话,f3函数是会执行的
}).then(function(){//f3
console.log('end');
});
f1函数执行结果返回了reject的状态,走到了f2的fail函数里了,在这里能阻止再执行f3函数吗?
如果朋友们有好的方式来处理reject的情况,可以show出代码让我学习学习啊。先表示感谢!
在第 2 個 then 的第二個函數裡加一句
throw 0
試試。當然 throw 的東西你可以自己定。一般情況下,會在最後加 reject 檢查,例如
如果第 1 個失敗,第 2 個會被跳過的。
試試改成下面的: