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

axios取消請(qǐng)求與避免重復(fù)請(qǐng)求

 更新時(shí)間:2021年06月22日 10:41:44   作者:KevinQ  
在項(xiàng)目中經(jīng)常有一些場(chǎng)景會(huì)連續(xù)發(fā)送多個(gè)請(qǐng)求,而異步會(huì)導(dǎo)致最后得到的結(jié)果不是我們想要的,并且對(duì)性能也有非常大的影響,這篇文章主要給大家介紹了關(guān)于axios取消請(qǐng)求與避免重復(fù)請(qǐng)求的相關(guān)資料,需要的朋友可以參考下

起源

某個(gè)頁(yè)面需要下載全部數(shù)據(jù)的功能,下載數(shù)據(jù)量大,接口延遲長(zhǎng).....

某個(gè)頁(yè)面加載初始數(shù)據(jù)量延長(zhǎng)長(zhǎng),但單個(gè)檢索快速,出現(xiàn)初始數(shù)據(jù)加載中時(shí),檢索接口返回,初始數(shù)據(jù)后續(xù)返回覆蓋了檢索數(shù)據(jù)的展示....

這些情況需要我們:

  • 能夠手動(dòng)取消/終止請(qǐng)求Request。
  • 某些頁(yè)面接口同時(shí)只能有一個(gè)在請(qǐng)求。

現(xiàn)狀

系統(tǒng)基于老哥花褲衩開源的vue-element-admin做的二次開發(fā),其中的請(qǐng)求采用的是axios,其中封裝的request.js關(guān)鍵代碼如下所示:

// create an axios instance
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
  withCredentials: true, // send cookies when cross-domain requests
  timeout: 500000, // request timeout
  transformRequest: [function(data) {
    // 對(duì) data 進(jìn)行任意轉(zhuǎn)換處理
    return Qs.stringify({
      ...data
    },
    // 數(shù)組的轉(zhuǎn)換
    { arrayFormat: 'brackets' })
  }]
})

// request interceptor
service.interceptors.request.use(
  config => {
    // do something before request is sent

    if (store.getters.token) {
      // let each request carry token
      // ['X-Token'] is a custom headers key
      // please modify it according to the actual situation
      config.headers['token'] = getToken()
    }
    return config
  },
  error => {
    // do something with request error
    console.log(error) // for debug
    return Promise.reject(error)
  }
)

發(fā)起請(qǐng)求的方法:

export function remoteApi(data) {
  return request({
    url: '/api',
    method: 'post',
    data
  })
}

取消請(qǐng)求 cancelToken

其官方文檔:取消:

const CancelToken = axios.CancelToken;
const source = CancelToken.source();

axios.get('/user/12345', {
  cancelToken: source.token
}).catch(function(thrown) {
  if (axios.isCancel(thrown)) {
    console.log('Request canceled', thrown.message);
  } else {
     // 處理錯(cuò)誤
  }
});

axios.post('/user/12345', {
  name: 'new name'
}, {
  cancelToken: source.token
})

// 取消請(qǐng)求(message 參數(shù)是可選的)
source.cancel('Operation canceled by the user.');

修改后的請(qǐng)求方法

export function remoteApi(data, cancelToken) {
  return request({
    url: '/api',
    method: 'post',
    cancelToken,
    data
  })
}

實(shí)際請(qǐng)求時(shí),創(chuàng)建cacelToken:

// 組件方法內(nèi)
this.cancelToken = CancelToken.source()
remoreApi(data, this.cancelToken).then(....).catch(....).finally(....)

需要取消請(qǐng)求時(shí),執(zhí)行:

// 組件方法內(nèi)
this.cancelToken.cancel('取消下載')

避免重復(fù)請(qǐng)求

避免一個(gè)接口的重復(fù)請(qǐng)求,以免延時(shí)長(zhǎng)的接口返回?cái)?shù)據(jù)覆蓋另一個(gè)接口的返回?cái)?shù)據(jù),造成數(shù)據(jù)顯示錯(cuò)誤。思路也相對(duì)簡(jiǎn)單,使用一個(gè)全局Map存儲(chǔ)請(qǐng)求標(biāo)識(shí)與對(duì)應(yīng)的cancelToken。請(qǐng)求,在發(fā)起請(qǐng)求前,按照請(qǐng)求標(biāo)識(shí),喚起對(duì)應(yīng)cancelToken的cancel方法,然后再發(fā)出新請(qǐng)求,即可滿足條件。

總結(jié)

到此這篇關(guān)于axios取消請(qǐng)求與避免重復(fù)請(qǐng)求的文章就介紹到這了,更多相關(guān)axios取消請(qǐng)求內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • antd vue表格可編輯單元格以及求和實(shí)現(xiàn)方式

    antd vue表格可編輯單元格以及求和實(shí)現(xiàn)方式

    這篇文章主要介紹了antd vue表格可編輯單元格以及求和實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue實(shí)現(xiàn)簡(jiǎn)單計(jì)算商品價(jià)格

    vue實(shí)現(xiàn)簡(jiǎn)單計(jì)算商品價(jià)格

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單計(jì)算商品價(jià)格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 前端實(shí)現(xiàn)簡(jiǎn)單的sse封裝方式(React hook Vue3)

    前端實(shí)現(xiàn)簡(jiǎn)單的sse封裝方式(React hook Vue3)

    這篇文章主要介紹了前端實(shí)現(xiàn)簡(jiǎn)單的sse封裝方式(React hook Vue3),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 3分鐘迅速學(xué)會(huì)Vue中methods方法使用技巧

    3分鐘迅速學(xué)會(huì)Vue中methods方法使用技巧

    最近在學(xué)習(xí)Vue,感覺(jué)methods還是有必有總結(jié)一下的,下面這篇文章主要給大家介紹了關(guān)于3分鐘迅速學(xué)會(huì)Vue中methods方法使用技巧的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • 淺析vue如何實(shí)現(xiàn)手機(jī)橫屏功能

    淺析vue如何實(shí)現(xiàn)手機(jī)橫屏功能

    在項(xiàng)目開發(fā)中有時(shí)候需求需要手動(dòng)實(shí)現(xiàn)橫屏功能,所以這篇文章主要為大家詳細(xì)介紹了如何使用Vue實(shí)現(xiàn)手機(jī)橫屏功能,需要的小伙伴可以參考一下
    2024-03-03
  • Vue微信小程序和uniapp配置環(huán)境地址

    Vue微信小程序和uniapp配置環(huán)境地址

    在微信小程序中,可以使用全局配置和使用開發(fā)、體驗(yàn)、生產(chǎn)環(huán)境的地址,這篇文章主要介紹了Vue微信和uniapp配置環(huán)境地址,需要的朋友可以參考下
    2023-07-07
  • 詳解vue3沙箱機(jī)制

    詳解vue3沙箱機(jī)制

    這篇文章主要介紹了詳解vue3 沙箱機(jī)制,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Vue組件實(shí)例間的直接訪問(wèn)實(shí)現(xiàn)代碼

    Vue組件實(shí)例間的直接訪問(wèn)實(shí)現(xiàn)代碼

    在組件實(shí)例中,Vue提供了相應(yīng)的屬性,包括$parent、$children、$refs和$root,這些屬性都掛載在組件的this上。本文將詳細(xì)介紹Vue組件實(shí)例間的直接訪問(wèn),需要的朋友可以參考下
    2017-08-08
  • 在Vue中如何實(shí)現(xiàn)打字機(jī)的效果

    在Vue中如何實(shí)現(xiàn)打字機(jī)的效果

    這篇文章主要介紹了在Vue中如何實(shí)現(xiàn)打字機(jī)的效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 如何在vue 中使用柱狀圖 并自修改配置

    如何在vue 中使用柱狀圖 并自修改配置

    這篇文章主要介紹了如何在vue 中使用柱狀圖 并自修改配置,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2021-01-01

最新評(píng)論