JavaScript詳解使用Promise處理回調(diào)地獄的兩種方法
一、.then()鏈?zhǔn)秸{(diào)用解決
多層回調(diào)函數(shù)的相互嵌套,就形成了回調(diào)地獄。
缺點(diǎn):
1.代碼耦合性太強(qiáng),難以維護(hù)。
2.大量冗余的代碼相互嵌套,可讀性比較差。
then-fs的基本使用:
調(diào)用then-fs(終端通過npm install then-fs安裝包)提供的readFile()方法,可以異步的讀取文件的內(nèi)容,它的返回值是Promise的實(shí)例對(duì)象,因此可以調(diào)用.then()方法為每個(gè)Promise異步操作指定成功和失敗之后的回調(diào)函數(shù)。
import thenFs from "then-fs" thenFs.readFile("./fis/1.txt","utf8").then(r1=>{ console.log(r1); }) thenFs.readFile("./fis/2.txt","utf8").then(r2=>{ console.log(r2); }) thenFs.readFile("./fis/3.txt","utf8").then(r3=>{ console.log(r3); })
但是會(huì)發(fā)現(xiàn)讀取順序是會(huì)變化的。
.then()方法的特性:
如果上一個(gè).then()方法中返回了一個(gè)新的promise實(shí)例對(duì)象,則可以通過下一個(gè).then()繼續(xù)進(jìn)行處理,通過鏈?zhǔn)秸{(diào)用的方法,解決地獄回調(diào)問題。
import thenFs from "then-fs" thenFs.readFile("./fis/1.txt","utf8").then(r1=>{ console.log(r1); return thenFs.readFile("./fis/2.txt","utf8") }).then(r2=>{ console.log(r2); return thenFs.readFile("./fis/3.txt","utf8") }).then(r3=>{ console.log(r3); })
.catch()方法
import thenFs from "then-fs" thenFs.readFile("./fis/11.txt","utf8").catch(err=>{ console.log(err.message); }).then(r1=>{ console.log(r1); return thenFs.readFile("./fis/2.txt","utf8") }).then(r2=>{ console.log(r2); return thenFs.readFile("./fis/3.txt","utf8") }).then(r3=>{ console.log(r3); })
.catch()放到最后可以捕獲所有錯(cuò)誤,但是一旦遇到錯(cuò)誤,后面的.then()就不在執(zhí)行。
.catch()放到前面,后面的.then()還可以正常執(zhí)行。
二、async await解決
import thenFs from "then-fs" async function getFile(){ // 不加await,打印的r1是一個(gè)promise實(shí)例對(duì)象,加await打印的是結(jié)果 const r1=await thenFs.readFile("./fis/1.txt","utf8") console.log(r1); const r2=await thenFs.readFile("./fis/2.txt","utf8") console.log(r2); const r3=await thenFs.readFile("./fis/3.txt","utf8") console.log(r3); } getFile()
注意:
在async方法中,第一個(gè)await之前的代碼會(huì)同步執(zhí)行,await之后的代碼會(huì)異步執(zhí)行
import thenFs from "then-fs" // 在async方法中,第一個(gè)await之前的代碼會(huì)同步執(zhí)行,await之后的代碼會(huì)異步執(zhí)行 console.log("a"); async function getFile(){ console.log("b"); const r1=await thenFs.readFile("./fis/1.txt","utf8") console.log(r1); const r2=await thenFs.readFile("./fis/2.txt","utf8") console.log(r2); const r3=await thenFs.readFile("./fis/3.txt","utf8") console.log(r3); console.log("d"); } getFile() console.log("c");
到此這篇關(guān)于JavaScript詳解使用Promise處理回調(diào)地獄的兩種方法的文章就介紹到這了,更多相關(guān)JS Promise回調(diào)地獄內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于JS實(shí)現(xiàn)頁面懸浮框的實(shí)例代碼
這篇文章主要介紹了基于JS實(shí)現(xiàn)頁面懸浮框的實(shí)例代碼,代碼簡單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12簡單實(shí)現(xiàn)js倒計(jì)時(shí)功能
這篇文章主要為大家詳細(xì)介紹了js倒計(jì)時(shí)效果的實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02JavaScript+html5 canvas制作色彩斑斕的正方形效果
這篇文章主要介紹了JavaScript+html5 canvas制作色彩斑斕的正方形效果,實(shí)例分析了JavaScript結(jié)合html5 canvas實(shí)現(xiàn)圖形動(dòng)態(tài)繪制的技巧,需要的朋友可以參考下2016-01-01JavaScript實(shí)現(xiàn)枚舉的幾種方法總結(jié)
在前端開發(fā)中,我們可能經(jīng)常需要用到枚舉,使用枚舉的好處是為了讓代碼的可讀性更強(qiáng),避免直接使用數(shù)字或未知的字符串,但是在JavaScript中,要自己實(shí)現(xiàn)一個(gè)枚舉功能,那么大家能想到多少種實(shí)現(xiàn)枚舉的方法呢,我將介紹幾種實(shí)現(xiàn)枚舉的好方法2023-08-08JavaScript實(shí)現(xiàn)異步圖像上傳功能
這篇文章主要介紹了JavaScript實(shí)現(xiàn)異步圖像上傳功能,本文展示了一種使用代碼示例立即顯示圖像的方法(使用圖像的Base64編碼版本),同時(shí)將其上載到服務(wù)器,而無需等待操作完成。需要的朋友可以參考下2018-07-07詳解JavaScript實(shí)現(xiàn)繼承的五種經(jīng)典方式(附圖解)
JavaScript中的繼承是一種機(jī)制,通過它可以創(chuàng)建一個(gè)對(duì)象,該對(duì)象可以享有另一個(gè)對(duì)象的屬性和方法,本文將詳細(xì)的為大家介紹實(shí)現(xiàn)繼承的五種經(jīng)典方式,感興趣的小伙伴跟著小編一起來看看吧2023-08-08