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

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

Promise 如何改變函數的使用

Promise 如何改變函數的使用

慕萊塢森 2023-12-14 15:11:35
我很難找到 Promise 的用途。下面這兩種方法的工作方式不是完全相同嗎?由于while循環loopTest()是同步的,logStatement()無論如何函數在完成之前都不會運行,所以第二種方法會有什么不同..等待它是沒有意義的嗎resolve()?第一種方法:function loopTest() {   while ( i < 10000 ) {       console.log(i)       i++   })}function logStatement() {     console.log("Logging test")}loopTest();logStatement();第二種方法:function loopTest() {   return new Promise((resolve, reject) => {      while ( i < 10000 ) {          console.log(i)          i++          if (i === 999) {           resolve('I AM DONE')          }      })   });   }function logStatement() {     console.log("Logging test")}loopTest().then(logStatement());
查看完整描述

4 回答

?
明月笑刀無情

TA貢獻1828條經驗 獲得超4個贊

承諾不會使任何事情異步,所以你是對的,在你所展示的代碼中使用承諾是沒有意義的。

Promise 的目的是提供一種標準的、可組合的方法來觀察異步事物(如 ajax 調用)的結果。

使用標準化方法來觀察異步操作的結果至少有三個巨大的好處:

  • 我們可以使用標準語義來使用各個 Promise,而不是每個 API 都為回調函數定義自己的簽名。(它是否使用成功時的初始參數發出錯誤信號null,如 Node.js?它是否使用帶有成功標志的對象調用回調?或者...)

  • 我們可以有標準的方式來組合它們,例如Promise.all、Promise.racePromise.allSettled等。

  • 我們可以使用語法來使用通常的控制結構來使用它們,這些控制結構現在以async函數 和 的形式存在await。

但同樣,在同步過程中拋出一個承諾幾乎永遠不會做任何有用的事情。2


1 一個非常小的警告:附加到 Promise 的處理函數總是異步觸發,無論 Promise 是否已經解決。

2 另一個小警告:有時,您希望將同步結果包含在Promise.all具有各種異步操作的組合操作(等)中。在這種情況下,將值包裝在立即履行的 Promise 中是有用的 - 事實上,所有標準 Promise 組合器(Promise.all等)都會為您執行此操作,就像 一樣await


查看完整回答
反對 回復 2023-12-14
?
慕后森

TA貢獻1802條經驗 獲得超5個贊

這是如何使用 Promise 的更好示例嗎?這就是我能想到的讓它對我有用的全部:


版本1


function getData() {


   fetch('https://jsonplaceholder.typicode.com/todos/1')

   .then(data => data.json())

   .then(json => console.log(json))

  

}



function logInfo() {

     console.log("i am a logger")

}


getData()

logInfo()


// "I am a logger"

//  {"test": "json"}

版本2


function getData() {


   return fetch('https://jsonplaceholder.typicode.com/todos/1')

   .then(data => data.json())

   .then(json => console.log(json))

  

}



function logInfo() {

     console.log("i am a logger")

}


getData().then(logInfo);

// "{"test": "json"}

// "I am a logger"

// waits for API result to log _then_ logInfo is run , which makes a log statement


查看完整回答
反對 回復 2023-12-14
?
慕斯王

TA貢獻1864條經驗 獲得超2個贊

使用 Promise 肯定有好處,但這只是在某些情況下,它們的使用似乎可行。


您的示例可以表示當您同步從外部源檢索數據時會發生什么,它會阻止線程執行進一步的代碼,直到循環終止(我在下面解釋為什么會發生這種情況) - 將其包裝在承諾中不會給出不同的輸出因為線程仍然被阻塞,并且當必須處理隊列中的下一條消息時,它會在結束后立即像平常一樣進行處理。


然而,與此類似的實現可以實現以非阻塞方式運行的 while 循環,這只是一個想法(并不意味著用 setInterval 的實現來破壞這個主題):


let f = () => {

  let tick = Date.now;

  let t = tick();

  let interval = setInterval(() => {

    if (tick() - t >= 3000) {

      console.log("stop");

      clearInterval(interval);

    }

  }, 0);

};

f()

console.log("start");

基本上,時間是在瀏覽器中的單獨線程中檢查/處理的,并且在調用堆棧變空之后,每次指定的時間用完而間隔尚未清除時都會執行回調(因此 UI 功能不受影響)當前正在執行的函數終止/結束或在堆棧中其上方的其他函數完成運行之后。我不知道這樣做對性能的影響,但我覺得這應該只在必要時使用,因為回調必須非常頻繁地執行(超時為 0,盡管無論如何都不能保證為 0) 。

為什么會發生

我主要想澄清的是,雖然處理程序函數將被安排為異步執行,但隊列中的每條消息都必須在下一條消息之前完全處理,并且在 while 循環執行期間,事件中不能處理新消息因此,如果沒有 Promise,同樣的事情也會發生,那么涉及 Promise 是毫無意義的。

所以基本上答案是:

等待它解析()不是毫無意義嗎?

是的,在這種情況下這是毫無意義的。


查看完整回答
反對 回復 2023-12-14
?
月關寶盒

TA貢獻1772條經驗 獲得超5個贊

你所做的事情沒有任何意義,因為你的函數體只是一個阻塞循環。

要從 Promises 中獲益,請將其與執行 IO 操作的 API 結合使用,例如 HTTP 請求或從磁盤讀取文件。

這些 API 傳統上都使用回調,現在大多基于 Promise。

任何使用基于 Promise 的函數的函數本身也應該是基于 Promise 的。這就是為什么您會在現代代碼中看到很多 Promise,因為 Promise 只需要在堆棧中的第 1 層使用,整個堆棧本質上就是異步的。


查看完整回答
反對 回復 2023-12-14
  • 4 回答
  • 0 關注
  • 200 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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