」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > .then(function(a){ return a; }) 是 Promises 的 No-Op 嗎?

.then(function(a){ return a; }) 是 Promises 的 No-Op 嗎?

發佈於2024-11-16
瀏覽:728

Is .then(function(a){ return a; }) a No-Op for Promises?

.then(function(a){ return a; }) 是 Promises 的 No-Op 嗎?

在 Promise 領域,就出現了 .then(function(a){ return a; }) 是否為空操作的問題。讓我們闡明這個奇怪的查詢:

是的,它通常是一個無操作。

相關程式碼接收前一個承諾的回傳值透過傳遞給 .then() 的函數進行連結。但是,如果函數僅傳回輸入 a,則它實際上繞過了 Promise 結果的任何處理或轉換。這使得它成為承諾管道中無害但不必要的額外步驟。

為什麼要這樣寫?

這可能是拼字錯誤或早期誤解的遺留物承諾。當引入 Promise 時,一些開發人員錯誤地認為 .then() 需要回傳一個 Promise 來繼續這條鏈。因此,他們添加了這個多餘的 .then() 調用,以確保返回的值始終保持承諾,即使它與輸入相同。

返回.then() 和省略它

雖然在語義上是等價的,但返回.then() 和省略它之間存在細微的區別:

  • 新的Promise 實例: .then () 建立一個新的Promise實例,而忽略它則重複使用原始實例。然而,這種區別通常是無關緊要的。
  • Thenable-ness 檢查: 使用 .then(),將檢查傳回的值以確定它是否為 Promise。省略 .then() 會跳過此檢查。

邊緣情況

在極少數情況下,.then(function(a){ return a; }) 可能會有不尋常的行為:

  • 如果回傳值在履行後突然變成一個Promise,.then() 會等待它。
  • 它傳回一個不同的 Promise 對象,這對於共享迴避。然而,這是一個利基用例。

結論

一般來說, .then(function(a){ return a; }) 是一個否-op 不會給承諾鏈增加任何價值。除非有令人信服的理由使用它,例如避免共享承諾或處理模糊的 thenable 相關行為,否則應將其省略。

最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3