您的位置:首頁 > 軟件教程 > 教程 > JavaScript編程中的Promise.withResolvers實踐

JavaScript編程中的Promise.withResolvers實踐

來源:好特整理 | 時間:2024-06-13 12:08:36 | 閱讀:172 |  標(biāo)簽: T VA AVA SC v Ri S C JavaScript LV IP 編程 AV java   | 分享到:

引言 在JavaScript編程中,Promise 是一種處理異步操作的常用機制。Promise 對象代表了一個尚未完成但預(yù)期將來會完成的操作的結(jié)果。在本文中,我們將探討如何通過使用 ES2024 的 Promise.withResolvers API 來優(yōu)化我們的 Promise 實現(xiàn)。 現(xiàn)有實現(xiàn)

在JavaScript編程中,Promise是一種處理異步操作的常用機制。該對象代表了一個尚未完成但預(yù)期將來會完成的操作的結(jié)果。本文將探討如何通過使用 ES2024 的Promise.withResolvers API來優(yōu)化Promise實現(xiàn)。

首先,讓我們看一個簡單的示例。以下代碼展示了在沒有使用Promise.withResolvers時,如何實現(xiàn)一個函數(shù),在傳入的另一個函數(shù)執(zhí)行完畢后2秒才返回結(jié)果:

const returnAfterTwoSeconds = (func, ...args) => {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      try {
        resolve(func(...args));
      } catch (e) {
        reject(e);
      }
    }, 2000);
  });
};

雖然上述代碼能夠正常工作,但它的嵌套層次較深,對于初次閱讀的人來說可能不夠直觀。

為了提高代碼的可讀性,我們可以對上述實現(xiàn)進行一些改進:

const returnAfterTwoSeconds = (func, ...args) => {
  let outerResolve = null;
  let outerReject = null;
  const promise = new Promise((resolve, reject) => {
    outerResolve = resolve;
    outerReject = reject;
  });

  setTimeout(() => {
    try {
      outerResolve(func(...args));
    } catch (e) {
      outerReject(e);
    }
  }, 2000);

  return promise;
};

在這個改進版本中,我們首先創(chuàng)建了一個Promise對象,并暫存了它的resolve和reject方法。然后在setTimeout中調(diào)用這些方法,最后返回Promise對象。這樣,即使setTimeout中的回調(diào)執(zhí)行完畢,返回的Promise對象也會根據(jù)回調(diào)的結(jié)果變?yōu)閞esolved或rejected。

現(xiàn)在,讓我們看看如何使用Promise.withResolvers來進一步簡化我們的代碼:

const returnAfterTwoSeconds = (func, ...args) => {
  const { promise, resolve, reject } = Promise.withResolvers();

  setTimeout(() => {
    try {
      resolve(func(...args));
    } catch (e) {
      reject(e);
    }
  }, 2000);

  return promise;
};

可以看到,這個方法并沒有為我們的代碼帶來性能或者說實現(xiàn)方式上的優(yōu)化,但是它使用起來很簡單,也很好理解,有助于提高代碼的可讀性和簡潔。

根據(jù)MDN文檔,Promise.withResolvers的語法如下:

  • 語法: Promise.withResolvers()
  • 參數(shù):無
  • 返回值:
    • promise : 一個Promise對象
    • resolve : 一個函數(shù),用于解決該Promise。關(guān)于其語義,請參閱構(gòu)造函數(shù)。
    • reject : 一個函數(shù),用于拒絕該Promise。關(guān)于其語義,請參閱構(gòu)造函數(shù)。

最后,我們可以自定義一個函數(shù)來模擬Promise.withResolvers的行為:

function myWithResolvers() {
  let resolve = null;
  let reject = null;
  const promise = new Promise((_resolve, _reject) => {
    resolve = _resolve;
    reject = _reject;
  });

  return { promise, resolve, reject };
}

可以看到,這個API在實現(xiàn)上其實也很簡單,只是把我們平常獲取promise中resolve和reject的步驟封裝到一個方法中,但為我們節(jié)省了很多時間。

小編推薦閱讀

好特網(wǎng)發(fā)布此文僅為傳遞信息,不代表好特網(wǎng)認(rèn)同期限觀點或證實其描述。

SC
SC
類型:飛行射擊  運營狀態(tài):正式運營  語言:中文   

游戲攻略

游戲禮包

游戲視頻

游戲下載

游戲活動

《SC》是游戲商天堂娛樂制作的一款末世生化題材的射擊生存游戲,游戲中,玩家將扮演幸存者,你需要利用物
RPG Ri序章 0.2.1
RPG Ri序章 0.2.1
類型:角色扮演  運營狀態(tài):正式運營  語言: 日文  

游戲攻略

游戲禮包

游戲視頻

游戲下載

游戲活動

《RPG_Ri序章》是GameMaker'Child-Dream'制作的一款幻想廢土風(fēng)RPG手游,完全免費的幻想廢土風(fēng)RPG登場!元

相關(guān)視頻攻略

更多

掃二維碼進入好特網(wǎng)手機版本!

掃二維碼進入好特網(wǎng)微信公眾號!

本站所有軟件,都由網(wǎng)友上傳,如有侵犯你的版權(quán),請發(fā)郵件[email protected]

湘ICP備2022002427號-10 湘公網(wǎng)安備:43070202000427號© 2013~2025 haote.com 好特網(wǎng)