欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

詳解Axios統(tǒng)一錯誤處理與后置

問題

創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)潁州,10年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

在進(jìn)行業(yè)務(wù)開發(fā)的時候,前后端會對接口的數(shù)據(jù)結(jié)構(gòu)進(jìn)行約定,若接口有異常,需要將異常信息展示給用戶知曉。這個流程里,數(shù)據(jù)結(jié)構(gòu)是確定的(事先約定),數(shù)據(jù)的處理邏輯是相同的(展示給用戶),如果在業(yè)務(wù)代碼代碼中重復(fù)的catch(e) { 展示給用戶 },就非常的不優(yōu)雅。本著Don't repeat myself(懶)的原則,需要對接口錯誤進(jìn)行統(tǒng)一處理。

接下來,我會結(jié)合具體的業(yè)務(wù)場景,講一講我的解決方案。

業(yè)務(wù)場景

  1. 后端通過http狀態(tài)標(biāo)識接口狀態(tài),錯誤信息在response的data里
  2. 前端的處理邏輯是使用element-ui的Message展示錯誤信息
  3. 使用axios

axios可以通過攔截器,在業(yè)務(wù)代碼處理響應(yīng)之前對響應(yīng)進(jìn)行處理,類似于下面的流程

someAPI()
  .then(interceptorsFn)
  .then(業(yè)務(wù)邏輯)

所以,我們可以在interceptors對響應(yīng)進(jìn)行統(tǒng)一處理:

request.interceptors.response.use(
  (response) => response.data,
  (error) => {
    // 針對特定的http狀態(tài)碼進(jìn)行處理
    if (error.response && error.response.status === 401) {
      router.push({ name: 'ssoLogin' })
      return new Promise(() => {}) // pending的promise,中止promise鏈
    }

    .....

    const msg = error.response.data
    Message.error(msg)

    return Promise.reject(error.response)
  }
)

如何進(jìn)行特定的錯誤處理

不難看出,上面的方案有一個問題,如果有某個接口需要有業(yè)務(wù)代碼來展示定制的錯誤信息(這個情況十分常見),如何處理?

naive方案1:業(yè)務(wù)代碼使用其它的方式展示信息:例如Notify。
這個方案被我司產(chǎn)品痛罵,因為破壞了統(tǒng)一的錯誤信息展示,并且此時統(tǒng)一的錯誤信息是一個垃圾信息,沒必要展示。

naive方案2:業(yè)務(wù)代碼直接使用Message,頂?shù)艚y(tǒng)一的錯誤信息。
這個方案還是被產(chǎn)品大哥(dog)懟了,因為明顯的用戶體驗不好,錯誤信息出現(xiàn)了閃爍。

帥氣的解決方案3:業(yè)務(wù)代碼決定是否隱藏統(tǒng)一錯誤提示
那么問題來了,由于是先走攔截器,再走業(yè)務(wù)代碼,如何由業(yè)務(wù)代碼決定是否隱藏統(tǒng)一錯誤提示呢?

我的辦法是,將統(tǒng)一的錯誤提示使用setTimeout放到下一個loop執(zhí)行,并通過一個變量標(biāo)識是否要執(zhí)行統(tǒng)一錯誤提示。

request.interceptors.response.use(
  (response) => response.data,
  (error) => {
    ...
    setTimeout(() => {
      if (tag) {
        Message.error(msg)
      }
    })
  }
)

接下來,需要考慮的是,如何在業(yè)務(wù)代碼里改變標(biāo)識變量

naive方案1:一個全局的變量或者方法

這個方案非常的不靠譜,若在其它代碼里改變了這個全局變量,就嗝屁,并且N個接口公用一個標(biāo)識變量,只能是同一個狀態(tài)。

帥氣方案2:

request.interceptors.response.use(
  (response) => response.data,
  (error) => {
    ...
    let isShowNormalError = true
    const hideNormalError = () => isShowNormalError = false

    setTimeout(() => {
      if (isShowNormalError) {
        Message.error(msg)
      }
    })

    return Promise.reject({ ...error.response, hideNormalMessage }) // 在error.response上添加方法
  }
)

業(yè)務(wù)代碼:

someAPIFN()
  .then()
  .catch({ data, hideNormalMessage }) {
    // 業(yè)務(wù)代碼
    hideNormalMessage()
  }

兼容舊代碼

目前的方案需要對現(xiàn)存代碼做修改,對進(jìn)行特殊處理的接口添加hideNormalMessage()。如果不想全局搜索添加代碼(懶),可以根據(jù)業(yè)務(wù)來進(jìn)行兼容。下面講一下我結(jié)合業(yè)務(wù)代碼進(jìn)行的兼容處理(非常不推薦)。

request.interceptors.response.use(
  (response) => response.data,
  (error) => {
    // warning,和業(yè)務(wù)代碼深度耦合,不推薦
    const hasMessageBeforeCatch = !!document.querySelector('.el-message')
    
    ...

    let isShowNormalError = true
    const hideNormalError = () => isShowNormalError = false

    setTimeout(() => {
      const hasMessageAfterCatch = document.querySelector('.el-message')

      // 調(diào)用catch前沒有message,調(diào)用catch后有message,表示message是在catch過程中產(chǎn)生
      const madeMessageWhenCatch = !hasMessageBeforeCatch && hasMessageAfterCatch

      if (isShowNormalError && !madeMessageWhenCatch) {
        Message.error(msg)
      }
    })

    return Promise.reject({ ...error.response, hideNormalMessage }) // 在error.response上添加方法
  }
)

邏輯:如果在catch中使用了Message,就不展示統(tǒng)一錯誤處理

總結(jié)

這個解決方案的關(guān)鍵在于使用setTimeout使得統(tǒng)一錯誤處理“落后”于業(yè)務(wù)代碼,并在Promise.reject的參數(shù)中添加控制函數(shù)使得業(yè)務(wù)代碼可以決定是否展示統(tǒng)一錯誤處理。稍作抽象與封裝就可以形成一個業(yè)務(wù)無關(guān)、框架無關(guān)的統(tǒng)一錯誤處理方案。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)站題目:詳解Axios統(tǒng)一錯誤處理與后置
網(wǎng)頁網(wǎng)址:http://aaarwkj.com/article26/pdeecg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、營銷型網(wǎng)站建設(shè)網(wǎng)站導(dǎo)航、外貿(mào)建站、自適應(yīng)網(wǎng)站電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
国产精品亚洲av三区国产毛片| 97视频精品在线播放| 亚洲av成人在线播放| 国产精品天干天综合网| 亚洲毛片一区二区在线| av在线高清免费观看| 久草福利在线观看免费| 国产精品大白屁股视频| 亚洲午夜av久久乱码| 国产精品一级性生活片| 精品亚洲午夜久久久久 | 精品国产视频一区二区三区| 蜜桃人妻av一区二区三区| 亚洲毛片在线免费播放| 91成人精品永久在线观看| 国产精品偷拍自拍视频| 日本成人大片在线观看| 国产成人原创免费观看| 欧美一区二区三区亚洲| 精品中文人妻中文字幕| 亚洲第一区二区国产精品| 午夜福利中文在线观看| 人妖激情一区二区三区| 亚洲 精品一区二区| 欧美亚洲清纯唯美另类| 国产91在线观看网站| 精品国产av一区蜜臀av| 婷婷中文字幕在线不卡视频 | 日韩av天堂免费网站| 一区二区日韩欧美国产| 成年人午夜在线观看网址| 偷怕自拍在线免费观看| 热久久青草精品欧美一区| 亚洲第一狼人天堂在线| 男人天堂在线视频网站| 偷窥偷拍原味一区二区三区| 亚洲欧美极品一区色婷婷| 国产三级系列在线观看| 精品人妻二区中文字幕| 日韩一级久久精品理论| 成人午夜在线三级内射|