溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Node.js中的Promise異步編程怎么掌握

發(fā)布時(shí)間:2023-05-05 10:48:40 來(lái)源:億速云 閱讀:102 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“Node.js中的Promise異步編程怎么掌握”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Node.js中的Promise異步編程怎么掌握”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

介紹 

  • Promise就是一個(gè)用來(lái)存儲(chǔ)數(shù)據(jù)的對(duì)象

  • 但是由于Promise存取方式的特殊,所以可以直接將異步調(diào)用的結(jié)果存儲(chǔ)到Promise中

function sum(a, b) {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            resolve(a + b)
        }, 1000)
    })
}
// 返回的是Promise,所以接收的時(shí)候不用變量接收,而是采用then獲取Promise存儲(chǔ)的數(shù)據(jù)
sum(123, 345).then(result => {
    console.log("結(jié)果為", result)
})

調(diào)用方法就會(huì)有返回值,而調(diào)用then、catch、finally三種方法都會(huì)產(chǎn)生一個(gè)新的Promise

const promise = new Promise((resolve, reject) => {
    resolve("沒(méi)問(wèn)題的數(shù)據(jù)")
})
const p2 = promise.then()
console.log(p2)

Node.js中的Promise異步編程怎么掌握

對(duì)Promise進(jìn)行鏈?zhǔn)秸{(diào)用時(shí),后面的方法(then和catch)讀取的是上一步的執(zhí)行結(jié)果

如果上一步的執(zhí)行結(jié)果不是當(dāng)前想要的結(jié)果,跳過(guò)當(dāng)前的方法

const promise = new Promise((resolve, reject) => {
    reject("沒(méi)問(wèn)題的數(shù)據(jù)")
})
// promise的鏈?zhǔn)秸{(diào)用
promise
    .then(r => console.log("第一個(gè)then", r))
    .catch(r =>  {
        console.log("異常處理", r)
        return "嘻嘻"
    })
    .then(r => console.log("第二個(gè)then", r))

打印結(jié)果為:

異常處理 沒(méi)問(wèn)題的數(shù)據(jù)
第二個(gè)then 嘻嘻

上述示例中,reject綁定了異常的數(shù)據(jù),下面的promise調(diào)用的第一個(gè)then方法顯然不會(huì)接收reject綁定的那個(gè)的數(shù)據(jù),即有問(wèn)題的數(shù)據(jù),所以第一個(gè)then被跳過(guò),catch則專(zhuān)門(mén)用來(lái)接收有問(wèn)題的數(shù)據(jù)和reject綁定的數(shù)據(jù),所以進(jìn)入和catch方法并打印 “沒(méi)問(wèn)題的數(shù)據(jù)" ,這個(gè)方法的結(jié)尾還有個(gè)return,這個(gè)return返回的 ”嘻嘻” 顯然是個(gè)正常數(shù)據(jù),執(zhí)行完catch后返回了正常數(shù)據(jù) “嘻嘻" 給新的promise,這個(gè)正確數(shù)據(jù)又被之后的 then方法捕捉到了,所以會(huì)把 ”嘻嘻" 接著打印出來(lái);每次調(diào)用catch、finally、then都會(huì)產(chǎn)生一個(gè)新的promise

當(dāng)Promise出現(xiàn)異常時(shí),而整個(gè)調(diào)用鏈中沒(méi)有catch,則異常則會(huì)向外拋出

所以一般都會(huì)在最后放catch方法,防止會(huì)有異常而沒(méi)有相應(yīng)的處理方法

靜態(tài)方法

Promise的靜態(tài)方法直接通過(guò)Promise類(lèi)去調(diào)用,這些方法可以幫助我們完成一些更加復(fù)雜的異步操作

Promise.resolve()

創(chuàng)建一個(gè)立即完成的Promise

Promise.resolve(10)
// 等價(jià)于
new Promise((resolve, reject) => {
    resolve(10)
})

Promise.all

  • 需要有多個(gè)Promise需要執(zhí)行,且需要多個(gè)Promise都執(zhí)行完畢,再將結(jié)果進(jìn)行統(tǒng)一處理,就使用Promise.all來(lái)處理

  • 語(yǔ)法: Promise.all(iterable)

  • Promise.all([...]) 同時(shí)但會(huì)多個(gè)Promise的執(zhí)行結(jié)果,其中有一個(gè)報(bào)錯(cuò),就返回錯(cuò)誤信息

  • all需要一個(gè)數(shù)組(可迭代對(duì)象) 作為參數(shù),數(shù)組種可以存放多個(gè)Promise

function sum(a, b) {
    return new Promise((reslove, reject) => {
        setTimeout(() => {
            reslove(a + b)
        }, 1000);
    })
}
Promise.all([sum(1, 1), sum(2, 3), sum(3, 3)])
    .then((result) => {
        console.log(result)
    })

上面的例子中,調(diào)用三次sum,且將其添加到數(shù)組中傳遞給all,調(diào)用all會(huì)返回一個(gè)新的Promise,當(dāng)三次計(jì)算都完成后,新的promise也會(huì)變成完成狀態(tài),并將三次執(zhí)行的結(jié)果封裝到數(shù)組中返回。\

// 添加的數(shù)據(jù)中一旦出現(xiàn)一個(gè)或者多個(gè)reject添加的錯(cuò)誤信息, 整體的運(yùn)行結(jié)果就會(huì)報(bào)錯(cuò)
Promise.all([sum(1, 1), sum(2, 3), sum(3, 3)], Promise.reject("哈哈"))
    .then((result) => {
        console.log(result)
    })

注意:在all中添加數(shù)據(jù),如果出現(xiàn)了一個(gè)或者多個(gè)通過(guò)reject添加的錯(cuò)誤信息,運(yùn)行結(jié)果就會(huì)報(bào)錯(cuò),一個(gè)錯(cuò),整個(gè)就錯(cuò)

Promise.allsSettled

  • Promise.allSettled( [...]) 同時(shí)返回多個(gè)Promise的運(yùn)行結(jié)果,無(wú)論成功還是失敗

  • 但是會(huì)根據(jù)不同得到狀態(tài)返回不同的數(shù)據(jù)

成功:{status:”fulfilled”, value:result}

失敗:{status:”rejected”, reason:error}

Promise.race race

  • 會(huì)返回首先執(zhí)行完的Promise,而忽略其他未執(zhí)行完的Promise

Promise.Any

  • any和race類(lèi)似,但是他只會(huì)返回第一個(gè)成功的Promise,如果所有的Promise都失敗才會(huì)返回一個(gè)錯(cuò)誤信息

讀到這里,這篇“Node.js中的Promise異步編程怎么掌握”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI