ホームページ >ウェブフロントエンド >jsチュートリアル >非同期 Promise 再試行にはどのような設計パターンが存在しますか?
Promise 再試行のパターンの設計
非同期プログラミングでは、失敗した Promise を解決するまで再試行すると便利なことがよくあります。 Promise でこれを実現するための 3 つの設計パターンを次に示します。
1. Promise が解決するまで再試行する (遅延と最大再試行数あり)
このパターンでは、Promise が正常に解決されるまで、各再試行の間に遅延を設けて再試行できます。 for ループを使用して .catch() ハンドラーのチェーンを作成し、続いて解決を成功させるための .then() ハンドラーを作成します。
<code class="javascript">var max = 5; var p = Promise.reject(); for(var i=0; i<max; i++) { p = p.catch(attempt).catch(rejectDelay); } p = p.then(processResult).catch(errorHandler);</code>
2.結果で条件が満たされるまで再試行 (遅延なし)
このパターンでは、結果で特定の条件が満たされるまで Promise を再試行できます。前のパターンと同様の .catch() チェーン アプローチを使用しますが、rejectDelay の代わりに .then() ハンドラーを使用して結果をテストします。
<code class="javascript">var max = 5; var p = Promise.reject(); for(var i=0; i<max; i++) { p = p.catch(attempt).then(test); } p = p.then(processResult).catch(errorHandler);</code>
3.結果が条件を満たすまで再試行 (遅延あり)
このパターンは前の 2 つのパターンを組み合わせたもので、条件が満たされるまで、各再試行の間に遅延を設けて Promise を再試行できます。 .catch() チェーンを使用して再試行を処理し、.then() ハンドラーを使用してテストを実行し、遅延を導入します。
<code class="javascript">var max = 5; var p = Promise.reject(); for(var i=0; i<max; i++) { p = p.catch(attempt).then(test).catch(rejectDelay); } p = p.then(processResult).catch(errorHandler);</code>
これらのパターンは、Promise による再試行を処理するための簡潔で効率的な方法を提供します。障害が発生した場合でもコードが確実に実行され続けるようにします。これらは、アプリケーションの特定のニーズに合わせてカスタマイズでき、最大再試行、遅延間隔、再試行条件などの要素のバランスをとることができます。
以上が非同期 Promise 再試行にはどのような設計パターンが存在しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。