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

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

 更新時(shí)間:2018年09月26日 10:10:00   作者:呱呱呱  
這篇文章主要介紹了詳解Axios統(tǒng)一錯(cuò)誤處理與后置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

問題

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

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

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

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

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

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

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

request.interceptors.response.use(
  (response) => response.data,
  (error) => {
    // 針對(duì)特定的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)行特定的錯(cuò)誤處理

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

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

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

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

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

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

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

naive方案1:一個(gè)全局的變量或者方法

這個(gè)方案非常的不靠譜,若在其它代碼里改變了這個(gè)全局變量,就嗝屁,并且N個(gè)接口公用一個(gè)標(biāo)識(shí)變量,只能是同一個(gè)狀態(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()
  }

兼容舊代碼

目前的方案需要對(duì)現(xiàn)存代碼做修改,對(duì)進(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)一錯(cuò)誤處理

總結(jié)

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

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue混淆與還原的實(shí)現(xiàn)

    Vue混淆與還原的實(shí)現(xiàn)

    混淆是一種有效的保護(hù)措施,可以加密和壓縮代碼,使其難以被理解和修改,本文將介紹Vue混淆的概念以及如何進(jìn)行還原,感興趣的可以了解一下
    2023-12-12
  • vue+element?ui表格添加多個(gè)搜索條件篩選功能(前端查詢)

    vue+element?ui表格添加多個(gè)搜索條件篩選功能(前端查詢)

    這篇文章主要給大家介紹了關(guān)于vue+element?ui表格添加多個(gè)搜索條件篩選功能的相關(guān)資料,最近在使用element-ui的表格組件時(shí),遇到了搜索框功能的實(shí)現(xiàn)問題,需要的朋友可以參考下
    2023-08-08
  • Vue實(shí)現(xiàn)模糊查詢-Mysql數(shù)據(jù)庫數(shù)據(jù)

    Vue實(shí)現(xiàn)模糊查詢-Mysql數(shù)據(jù)庫數(shù)據(jù)

    這篇文章主要介紹了基于Vue實(shí)現(xiàn)Mysql數(shù)據(jù)庫數(shù)據(jù)模糊查詢,下面文章我們主要實(shí)現(xiàn)的是輸入框中輸入數(shù)據(jù),根據(jù)輸入的結(jié)果模糊搜索數(shù)據(jù)庫對(duì)應(yīng)內(nèi)容,實(shí)現(xiàn)模糊查詢,感興趣的小伙伴可以進(jìn)入文章我們一起學(xué)習(xí)
    2021-12-12
  • Vue2中無法檢測到數(shù)組變動(dòng)的原因及解決

    Vue2中無法檢測到數(shù)組變動(dòng)的原因及解決

    由于某些限制,vue2不能檢測到某些情況下數(shù)組的變動(dòng),本文就將具體講解這兩種限制的解決思路
    2021-06-06
  • ElementUI修改實(shí)現(xiàn)更好用圖片上傳預(yù)覽組件

    ElementUI修改實(shí)現(xiàn)更好用圖片上傳預(yù)覽組件

    這篇文章主要為大家介紹了ElementUI修改實(shí)現(xiàn)更好用圖片上傳預(yù)覽組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue 怎么創(chuàng)建組件及組件使用方法

    vue 怎么創(chuàng)建組件及組件使用方法

    vue中的核心就是組件,組件 (Component) 是 Vue.js 最強(qiáng)大的功能之一。組件可以擴(kuò)展 HTML 元素,封裝可重用的代碼,下面通過本文重點(diǎn)給大家介紹vue 創(chuàng)建組件及組件使用方法,感興趣的朋友一起看看吧
    2017-07-07
  • vue項(xiàng)目中的遇錯(cuò):Invalid?Host?header問題

    vue項(xiàng)目中的遇錯(cuò):Invalid?Host?header問題

    這篇文章主要介紹了vue項(xiàng)目中的遇錯(cuò):Invalid?Host?header問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • element中drawer模板的實(shí)現(xiàn)

    element中drawer模板的實(shí)現(xiàn)

    本文主要介紹了element中drawer模板的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue中vite.config.js配置跨域以及環(huán)境配置方式

    vue中vite.config.js配置跨域以及環(huán)境配置方式

    這篇文章主要介紹了vue中vite.config.js配置跨域以及環(huán)境配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程

    vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程

    這篇文章主要為大家詳細(xì)介紹了vue集成openlayers加載geojson并實(shí)現(xiàn)點(diǎn)擊彈窗教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09

最新評(píng)論