亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

項目中如何使用axios過濾多次重復(fù)請求詳解

 更新時間:2021年07月07日 11:26:13   作者:峰峰會很好  
在項目開發(fā)中經(jīng)常需要處理重復(fù)點擊導(dǎo)致多次調(diào)用接口的問題,這篇文章主要介紹了項目中如何使用axios過濾多次重復(fù)請求的相關(guān)資料,需要的朋友可以參考下

一、前言:

我們在web應(yīng)用開發(fā)過程當(dāng)中,經(jīng)常會遇到一個時刻發(fā)起了多個請求的場景

這個情況下,我們通常的做法有兩種:

  • 可以在請求時show一個loading,阻止用戶操作。
  • 或者人為加個變量,做一個請求的節(jié)流

我們的項目中,目前大部分情況也是采用以上兩種方式做的。今天來介紹一個新的方式。

二、CancelToken類

我們之前實例化一個Promise,這個對象是否成功與否,是無法在函數(shù)外部決定的,這里邊使用要用到一個小竅門,可以讓一個promise 和resolve分離。任何時機(jī)都可以觸發(fā)resolve:

  // 一個promise
  let resolvePromise
  let p = new Promise((resolve, reject) => {
    resolvePromise = resolve
  })
  // 這樣在外部執(zhí)行
  resolvePromise()

ok,有了這個前提,我們需要借助axios.CancelToken這個類。

這個類相當(dāng)于在每次請求的時候開啟另一個promise和當(dāng)前的請求形成一個promise.race(請求p1,取消請求p2),在promise中的resolve方法賦值給了一個外部的變量去接收。我們可以根據(jù)需求,人為決定是否取消前次請求。其實這就類似,原來我們寫fetch封裝接口超時的Promise.race類似。

cancelToken中也提供了相應(yīng)的static方法source用來生成一個cancelToken和一個cancel方法其實就是這個promise的一個resolve。

    CancelToken.source = function source() {
    var cancel;
    // 
    var token = new CancelToken(function executor(c) {
        cancel = c;
    });
    return {
        token: token,
        cancel: cancel,
    };

根據(jù)我們常用的的緩存方式,我們可以聲明一個map來存儲每次請求的url,同時存儲對應(yīng)的cancel方法。

    // 聲明一個全局map
    const pendingHttp = new Map()
    // axios中內(nèi)置的CancelToken類
    const CancelToken = axios.CancelToken
       
    function addApi (config) {
      config.cancelToken = new CancelToken((cancel) => {
        const url = config.url
        console.log(pendingHttp)
        if (!pendingHttp.has(url)) {
          pendingHttp.set(url, cancel)
        }
      })
    }

    function cancelApi (config) {
      const url = config.url
      if (pendingHttp.has(url)) { // 如果在 pending 中存在當(dāng)前請求標(biāo)識,需要取消當(dāng)前請求,并且移除
        const cancel = pendingHttp.get(url)
        cancel(url + '取消了')
        pendingHttp.delete(url) // 清空當(dāng)前url的緩存
      }
    }
  • 要特殊注意,要想取消掉一個請求,需要在config上添加cancelToken這個屬性賦值為CancelToken的實例。否則cancel不掉。

就像操作定時器一樣,要先嘗試取消上一次,然后再開啟下一次

    httpService.interceptors.request.use(config => {

      cancelApi(config)
      addApi(config)
      
      // 本地調(diào)試的時候,是跨域的情況,加請求頭會有限制(此處是項目代碼無關(guān)緊要)
      const { headers = {} } = config; const { globalObj = {} } = window
      Object.assign(headers, globalObj, { from })
      
      return config
    }, error => {
      console.log(error)
      return Promise.reject(error)
    })

然后還有一種可能性,第一次請求已經(jīng)返回了,又發(fā)起了相同的一次請求,所以在response里邊也要cancelApi一下。

    httpService.interceptors.response.use(
      response => {
        cancelApi(response.config)
        sentryCatchApi(response)
      },
      error => {
        // 請求超時
        if (error.message.includes('timeout')) { // 判斷請求異常信息中是否含有超時timeout字符串
          Toast.error({ text: '網(wǎng)頁請求超時,請刷新重試~' })
        }
        sentryCatchApi(error)
        return Promise.reject(error)
      }
    )

我們需要注意一點,cancel其實就是resolve,我們cancel執(zhí)行時候傳入的參數(shù),會最終在response的error回調(diào)中,作為參數(shù)返回,這樣我們的捕捉錯誤的方法可能會有報錯。

    // 假設(shè)我們的error方法是這樣封裝的。 來看一下sentryCatchApi
    error => {
      sentryCatchApi(error)
      return Promise.reject(error)
    }
  // 由于這個方法需要接收一個對象,但是我們cancel取消請求的情況下,返回的是一個字符串,這時就報錯了。
  function sentryCatchApi (res) {
      try {
        res = res || {}
        const resData = res.data || {}
        Sentry.captureException(JSON.stringify(resData))
        console.log(`
          獲取數(shù)據(jù)失敗:
          請在瀏覽器中打開進(jìn)入 webview的地址,并粘貼出來,便于問題排查
          :接口相關(guān)信息:
          接口地址:${res.config.url},
          接口返回值:code:${resData.code},
          message:${resData.message},
          data:${JSON.stringify(resData.data)}
        `)
      } catch (err) {
        console.error(err)
      }
    }

需要使用isCancel這個api

   error => {
    if (axios.isCancel(error)) return console.log('請求被取消了', error.message)
    sentryCatchApi(error)
    return Promise.reject(error)
  }

最終效果

控制臺也沒有任何報錯啦。(后續(xù)完善到項目中)

總結(jié)

到此這篇關(guān)于項目中如何使用axios過濾多次重復(fù)請求的文章就介紹到這了,更多相關(guān)axios過濾多次重復(fù)請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue工程全局設(shè)置ajax的等待動效的方法

    vue工程全局設(shè)置ajax的等待動效的方法

    這篇文章主要介紹了vue工程全局設(shè)置ajax的等待動效的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • 淺談Vue3.0新版API之composition-api入坑指南

    淺談Vue3.0新版API之composition-api入坑指南

    這篇文章主要介紹了Vue3.0新版API之composition-api入坑指南,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 淺談vue項目4rs vue-router上線后history模式遇到的坑

    淺談vue項目4rs vue-router上線后history模式遇到的坑

    今天小編就為大家分享一篇淺談vue項目4rs vue-router上線后history模式遇到的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue-video-player 解決微信自動全屏播放問題(橫豎屏導(dǎo)致樣式錯亂問題)

    vue-video-player 解決微信自動全屏播放問題(橫豎屏導(dǎo)致樣式錯亂問題)

    這篇文章主要介紹了vue-video-player 解決微信自動全屏播放問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • vue-router中query和params的區(qū)別解析

    vue-router中query和params的區(qū)別解析

    vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,適合用于構(gòu)建單頁面應(yīng)用,這篇文章主要介紹了vue-router中query和params的區(qū)別 ,需要的朋友可以參考下
    2022-10-10
  • vue開發(fā)中后臺系統(tǒng)復(fù)雜表單優(yōu)化技巧

    vue開發(fā)中后臺系統(tǒng)復(fù)雜表單優(yōu)化技巧

    這篇文章主要為大家介紹了vue開發(fā)中后臺系統(tǒng)復(fù)雜表單的優(yōu)化技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Vue-cli3項目配置Vue.config.js實戰(zhàn)記錄

    Vue-cli3項目配置Vue.config.js實戰(zhàn)記錄

    這篇文章主要給大家介紹了關(guān)于Vue-cli3項目配置Vue.config.js的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • vue卡片式點擊切換圖片組件使用詳解

    vue卡片式點擊切換圖片組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了vue卡片式點擊切換圖片組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • vue雙向綁定數(shù)據(jù)限制長度的方法

    vue雙向綁定數(shù)據(jù)限制長度的方法

    這篇文章主要為大家詳細(xì)介紹了vue雙向綁定數(shù)據(jù)限制長度的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 詳解Vue自定義指令如何實現(xiàn)處理圖片加載失敗的碎圖

    詳解Vue自定義指令如何實現(xiàn)處理圖片加載失敗的碎圖

    這篇文章主要介紹了詳解Vue自定義指令如何實現(xiàn)處理圖片加載失敗的碎圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02

最新評論