javascript – 承诺被拒绝后抛出错误 – 问:
作者:互联网
以下是使用Q的承诺的简短示例.
这是test1.js:
function testDefer() {
var deferred = Q.defer();
fs.readFile("foo.txt", "utf-8", function (error, text) {
if (error) {
deferred.reject(new Error(error));
} else {
deferred.resolve(text);
}
});
return deferred.promise;
}
这是test2.js
(function(){
'use strict';
var test1 = require('./test1');
test1.testDefer().then(
function(data){
console.log('all good');
},
function(err) {
//upon error i might want to throw an exception, however, it is not thrown / ignored.
throw new Error('I want to throw this exception');
}
);
})();
我想在test2中抛出异常,以防止承诺被拒绝(或者在某些情况下它被解决).无论如何,异常被忽略,程序完成而不抛出异常.
我的问题是,如何从成功/失败函数中抛出错误?
谢谢
解决方法:
处理器中的所有错误都被捕获并用于拒绝生成的承诺.你想要的是done
method:
Much like
then
, but with different behavior around unhandled
rejection. If there is an unhandled rejection, either because
promise
is rejected and noonRejected
callback was provided, or
becauseonFulfilled
oronRejected
threw an error or returned a
rejected promise, the resulting rejection reason is thrown as an
exception in a future turn of the event loop.This method should be used to terminate chains of promises that will
not be passed elsewhere. Since exceptions thrown inthen
callbacks
are consumed and transformed into rejections, exceptions at the end of
the chain are easy to accidentally, silently ignore. By arranging for
the exception to be thrown in a future turn of the event loop, so that
it won’t be caught, it causes anonerror
event on the browser
window
, or anuncaughtException
event on Node.js’sprocess
object.The Golden Rule of
done
vs.then
usage is: eitherreturn
your
promise to someone else, or if the chain ends with you, calldone
to
terminate it.
Q.ninvoke(fs, "readfile", "foo.txt", "utf-8").done(function(data){
console.log('all good');
}, function(err) {
throw new Error('I want to throw this exception');
}); // or omit the error handler, and 'err' will be thrown
标签:q,javascript,node-js,promise 来源: https://codeday.me/bug/20191008/1872888.html