亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

await for Promise 的結果返回一個承諾?

await for Promise 的結果返回一個承諾?

慕婉清6462132 2021-10-14 15:54:04
我有一個像這樣的簡單函數,我期待著它true。它創建一個Observablefrom true,把它變成一個 promise,然后await:    async function returnTrue() {      return await of(true).toPromise();    }    var b = returnTrue();    console.log("b is: ", b);當b記錄的值時,它會記錄:b is:Promise {}IIUC 執行此操作的另一種方法是pipe像這樣對 observable 進行處理:function returnFalse() {  return of(false).pipe(map(b=>{    return b;    }));}const c = returnFalse();console.log('Return value c: ', c);在這種情況下,記錄的值是:Return value c:Observable {_isScalar: false, source: {…}, operator: {…}}想法?概括總結了這個問題的答案,以便使用 RxJS Observables 進行同步編程:https://medium.com/p/6276721e674a
查看完整描述

2 回答

?
慕哥9229398

TA貢獻1877條經驗 獲得超6個贊

async函數上下文返回的任何值都包裝在 Promise 中。

在您的代碼中,雖然您返回的結果await實際上等待of(true).toPromise()Promise 得到解決,但確實如此,但由于async函數上下文,已解決的值再次包裝在承諾中。

這在 MDN的async函數文檔中有說明:

async 函數聲明定義了一個異步函數,它返回一個 AsyncFunction 對象。異步函數是通過事件循環異步操作的函數,使用隱式 Promise 返回其結果

在使用的第二個代碼中Observable,您使用的pipe運算符根據定義Observable在應用文檔中的給定操作(在您的情況下為映射)后返回另一個:

pipe(operations: ...*): Observable

返回: Observable 所有已按傳入順序調用的運算符的 Observable 結果。


查看完整回答
反對 回復 2021-10-14
?
喵喵時光機

TA貢獻1846條經驗 獲得超7個贊

嘗試這個:

var b = await returnTrue()

附注。忘記 var - 閱讀 const & let


查看完整回答
反對 回復 2021-10-14
  • 2 回答
  • 0 關注
  • 218 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號