參考文章:
Promise|MDN
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise
通俗淺顯的理解Promise中的then:
https://www.cnblogs.com/morongwendao/p/9875443.html
Promise 對(duì)象用于表示一個(gè)異步操作的最終完成 (或失敗), 及其結(jié)果值.
Promise 對(duì)象是一個(gè)代理對(duì)象(代理一個(gè)值),被代理的值在Promise對(duì)象創(chuàng)建時(shí)可能是未知的。它允許你為異步操作的成功和失敗分別綁定相應(yīng)的處理方法(handlers)
一個(gè) Promise有以下幾種狀態(tài):
pending: 初始狀態(tài),既不是成功,也不是失敗狀態(tài)。
fulfilled: 意味著操作成功完成。
rejected: 意味著操作失敗。
pending 狀態(tài)的 Promise 對(duì)象可能會(huì)變?yōu)閒ulfilled 狀態(tài)并傳遞一個(gè)值給相應(yīng)的狀態(tài)處理方法,也可能變?yōu)槭顟B(tài)(rejected)并傳遞失敗信息。當(dāng)其中任一種情況出現(xiàn)時(shí),Promise 對(duì)象的 then 方法綁定的處理方法(handlers )就會(huì)被調(diào)用(then方法包含兩個(gè)參數(shù):onFulfilled(如果 onFulfilled 不是函數(shù),其必須被忽略) 和 onRejected,它們都是 Function 類型。當(dāng)Promise狀態(tài)為fulfilled時(shí),調(diào)用 then 的 onFulfilled 方法,當(dāng)Promise狀態(tài)為rejected時(shí),調(diào)用 then 的 onRejected 方法, 所以在異步操作的完成和綁定處理方法之間不存在競(jìng)爭(zhēng))。
then方法提供一個(gè)供自定義的回調(diào)函數(shù),若傳入非函數(shù),則會(huì)忽略當(dāng)前then方法。
回調(diào)函數(shù)中會(huì)把上一個(gè)then中返回的值當(dāng)做參數(shù)值供當(dāng)前then方法調(diào)用。
then方法執(zhí)行完畢后需要返回一個(gè)新的值給下一個(gè)then調(diào)用(沒有返回值默認(rèn)使用undefined)。
每個(gè)then只可能使用前一個(gè)then的返回值。