連鎖された Promise が拒否を伝えない
連鎖された Promise は、前の Promise への意図的な依存関係にもかかわらず、エラーを伝播できない可能性があります。この動作は不可解かもしれませんが、Promise/A の性質に根ざしています。
誤解: チェーンの依存関係
誤解は、それぞれが先行するものへの依存関係を暗示しているということです。プロミスの成功した解決。しかし、これは当てはまりません。
Promise Chaining
Promise Chaining では、then のコールバック関数の結果が後続の Promise の解決になります。したがって:
処理拒否
then コールバックで Promise がスローまたは拒否されたエラーは、次の Promise の catch または error コールバックをトリガーします。ただし、エラーがコールバック内で処理された場合、Promise が正常に解決されたかのようにチェーンが続行します。
例:
次のコードを考えてみましょう:
let promise1 = Promise.resolve(42); let promise2 = promise1.then( (value) => value * 2, (err) => { console.error('Error in promise1:', err); // Handle the error (e.g., return a new promise) } ); promise2.then((value) => console.log('Value from promise2:', value));
この例では、promise1 が拒否された場合、そのエラー ハンドラーはエラーをログに記録し、デフォルト値を返します。これにより、promise2 は、promise1 から正常な応答を受信したかのように処理を進めることができます。
アプリケーションからデータベースの更新まで
データベースの更新の例では、db.query のエラーが発生します。は then コールバックで処理され、デフォルト値が提供されます。これにより、db.query が失敗した場合でも、後続の then コールバックを続行し、データベースの更新を実行できます。
ベスト プラクティス
一貫したエラー処理を確保するには、次のことを考慮してください。次のベスト プラクティス:
以上が連鎖的な約束が拒否を無視することがあるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。