Promise.reject 與throw:揭示差異
JavaScript 開發中常見的困境是理解Promise.reject 和throwing 之間的區別錯誤。雖然這兩種策略都可以用於處理錯誤,但在特定場景中會出現細微的差異。
在 Promise 回呼的上下文中,使用 throw 有效地發出錯誤訊號,並且以下 catch 處理程序將捕獲它。但是,當在 Promise 回呼之外工作時,如果使用 throw,則不會呼叫 catch 處理程序。為了解決這個問題,必須使用 Promise.reject。
考慮以下程式碼:
使用Promise.reject:
<code class="javascript">return asyncIsPermitted() .then(function(result) { if (result === true) { return true; } else { return Promise.reject(new PermissionDenied()); } });</code>
使用throw:
<code class="javascript">return asyncIsPermitted() .then(function(result) { if (result === true) { return true; } else { throw new PermissionDenied(); } });</code>在上面的範例中, throw 方法將在任何Promise 回調中觸發catch 處理程序。但是,如果 asyncIsPermission() 不是一個 Promise,而是一個執行非同步處理的函式(使用 setTimeout 或類似方法),則 catch 不會處理 throw。在這種情況下,應該使用 Promise.reject 來確保捕獲錯誤。 因此,雖然 throw 由於其簡潔性可能更可取,但 Promise.reject 提供了更大的靈活性,應該在必要時使用以確保非承諾回調上下文中的錯誤處理。
以上是何時使用 Promise.reject 而不是 Throw?的詳細內容。更多資訊請關注PHP中文網其他相關文章!