欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript詳解使用Promise處理回調(diào)地獄的兩種方法

 更新時(shí)間:2022年11月30日 10:59:04   作者:未及545  
這篇文章主要介紹了JavaScript詳解使用Promise處理回調(diào)地獄的兩種方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一、.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í)例代碼

    這篇文章主要介紹了基于JS實(shí)現(xiàn)頁面懸浮框的實(shí)例代碼,代碼簡單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • JS文本框不能輸入空格驗(yàn)證方法

    JS文本框不能輸入空格驗(yàn)證方法

    JS文本框不能輸入空格驗(yàn)證方法,需要的朋友可以參考一下
    2013-03-03
  • 微信小程序圖表插件(wx-charts)實(shí)例代碼

    微信小程序圖表插件(wx-charts)實(shí)例代碼

    這篇文章主要介紹了微信小程序圖表插件(wx-charts)實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • 簡單實(shí)現(xiàn)js倒計(jì)時(shí)功能

    簡單實(shí)現(xiàn)js倒計(jì)時(shí)功能

    這篇文章主要為大家詳細(xì)介紹了js倒計(jì)時(shí)效果的實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • JavaScript+html5 canvas制作色彩斑斕的正方形效果

    JavaScript+html5 canvas制作色彩斑斕的正方形效果

    這篇文章主要介紹了JavaScript+html5 canvas制作色彩斑斕的正方形效果,實(shí)例分析了JavaScript結(jié)合html5 canvas實(shí)現(xiàn)圖形動(dòng)態(tài)繪制的技巧,需要的朋友可以參考下
    2016-01-01
  • 淺析js 文字滾動(dòng)效果

    淺析js 文字滾動(dòng)效果

    文字滾動(dòng)顯示,是網(wǎng)頁企業(yè)公告,文字鏈廣告常用的一種效果,說不定在什么時(shí)候你就能看到它。
    2010-05-05
  • JavaScript實(shí)現(xiàn)枚舉的幾種方法總結(jié)

    JavaScript實(shí)現(xiàn)枚舉的幾種方法總結(jié)

    在前端開發(fā)中,我們可能經(jīng)常需要用到枚舉,使用枚舉的好處是為了讓代碼的可讀性更強(qiáng),避免直接使用數(shù)字或未知的字符串,但是在JavaScript中,要自己實(shí)現(xiàn)一個(gè)枚舉功能,那么大家能想到多少種實(shí)現(xiàn)枚舉的方法呢,我將介紹幾種實(shí)現(xiàn)枚舉的好方法
    2023-08-08
  • JavaScript實(shí)現(xiàn)異步圖像上傳功能

    JavaScript實(shí)現(xiàn)異步圖像上傳功能

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)異步圖像上傳功能,本文展示了一種使用代碼示例立即顯示圖像的方法(使用圖像的Base64編碼版本),同時(shí)將其上載到服務(wù)器,而無需等待操作完成。需要的朋友可以參考下
    2018-07-07
  • JS實(shí)現(xiàn)導(dǎo)航欄樓層特效

    JS實(shí)現(xiàn)導(dǎo)航欄樓層特效

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)導(dǎo)航欄樓層特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • 詳解JavaScript實(shí)現(xiàn)繼承的五種經(jīng)典方式(附圖解)

    詳解JavaScript實(shí)現(xiàn)繼承的五種經(jīng)典方式(附圖解)

    JavaScript中的繼承是一種機(jī)制,通過它可以創(chuàng)建一個(gè)對(duì)象,該對(duì)象可以享有另一個(gè)對(duì)象的屬性和方法,本文將詳細(xì)的為大家介紹實(shí)現(xiàn)繼承的五種經(jīng)典方式,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08

最新評(píng)論