1. ホーム
  2. javascript

[解決済み] Promise : then vs then + catch [重複].

2022-07-26 21:06:56

質問

以下の2つのコードに違いはありますか?

myPromise.then(function() {
    console.log('success');
}).catch(function() {
    console.log('error');
});

myPromise.then(function() {
    console.log('success');
}, function() {
    console.log('error');
});

私は知っている thencatch はコールバックで返された値で解決または拒否された新しいプロミスを返します。しかし、私はウェブ上で2つのコードを見かけ、私は2つのコードの間の本当の違いについて興味があります。

どのように解決するのですか?

現在のコードでは、両者は同じように動作します。 console.log('success'); は失敗しないので、同じように動作します。

ところが、こんな風に書いてしまうと...。

myPromise.then(function() {
   // Some error may happen
   throw('An exception that would be caught');
}).catch(function() {
    console.log('error');
});
// Is the same as this, the errHandle tries to catch any unhandled error
// from previous result.
myPromise.then(func, null).then(null, errHandle);


myPromise.then(function() {
   // Some error may happen
   throw('An unhandled exception.');
}, function() {
    // This won't log the error if it happens in the 
    // some error may happen block.
    console.log('error');
});
// Is the same as this, the errHandle will handle errors from previous result,
// but it won't handle errs in func.
myPromise.then(func, errHandle)

2番目のフォームはそのエラーを捕捉できませんが、1番目のフォームは捕捉できます。

テスト用のスニペットです。

// An function that may error and throw exception.
function funcThatThrows(test) {
  throw(`oops - error in test ${test}`);
}
function errHandler(exception) {
  console.log('We got an exception: ', exception);
}
// Expect: We got an exception:  oops - error in test 1
Promise.resolve(1).then(funcThatThrows).catch(errHandler);
// Is the same as below, the errHandler tries to catch any unhandled error
// from previous result.
// Expect: We got an exception:  oops - error in test 2
Promise.resolve(2).then(funcThatThrows, null).then(null, errHandler);

// If put the function and handler in the same then, the exception won't be caught.
// Expect: Uncaught (in promise) oops - error in test 3
Promise.resolve(3).then(funcThatThrows, errHandler);