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

axios取消請求CancelToken的用法示例代碼

 更新時間:2023年10月10日 08:57:51   作者:康師傅不會煮面  
Axios提供了取消請求的功能,可以通過使用CancelToken來實現(xiàn),這篇文章主要給大家介紹了關(guān)于axios取消請求CancelToken的用法,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

axios中取消請求情況分為1:取消該請求之后的相同請求;2:取消該請求之前的相同請求

取消該請求之后的相同請求:

在使用 axios 發(fā)送請求時,如果在短時間內(nèi)連續(xù)發(fā)送同一個請求,可能會出現(xiàn)請求結(jié)果混亂或重復(fù)響應(yīng)的問題。為了避免這種情況,我們可以使用 axios 的取消請求功能,每次發(fā)送請求前先取消之前的請求。下面是使用 axios 取消請求的示例代碼:

import axios from 'axios';
 // 創(chuàng)建一個 CancelToken 對象
const source = axios.CancelToken.source();
 // 發(fā)送請求
axios.get('/api/data', {
  // 將 cancelToken 屬性設(shè)置為上面創(chuàng)建的 CancelToken 實例
  cancelToken: source.token
}).then(response => {
  console.log(response.data);
}).catch(error => {
  console.error(error);
});
 // 取消之前的請求
source.cancel('Duplicate request');

在上面的代碼中,我們先創(chuàng)建一個 CancelToken 對象 source ,并將其傳遞給發(fā)送請求的 cancelToken 屬性中。然后在需要取消之前請求的時候,調(diào)用 source.cancel() 方法即可。此時,后續(xù)的請求將不會被發(fā)送,以避免重復(fù)響應(yīng)。

需要注意的是,如果在請求被取消之前,請求已經(jīng)被發(fā)送并成功響應(yīng),那么該已經(jīng)成功響應(yīng)的請求結(jié)果無法被取消,因此也需要對已經(jīng)成功響應(yīng)的請求結(jié)果做好處理。另外,也需要處理請求被取消的異常情況,以避免出現(xiàn)錯誤。

取消該請求之前的相同請求:

在 axios 中,取消上一次請求與取消前面的所有請求是有差別的。取消上一次請求,我們可以記錄當前請求的 cancelToken ,然后在下一次請求之前發(fā)送一個取消請求的操作。而取消前面的所有請求,我們需要維護一份請求隊列,然后在新的請求發(fā)起之前,將之前的所有請求都取消掉。

下面是一個實現(xiàn)取消前面的所有請求的例子:

import axios from 'axios';
 // 創(chuàng)建一個請求隊列
let pending = [];
const CancelToken = axios.CancelToken;
const removePending = (config) => {
  for (let p in pending) {
    if (pending[p].url === config.url + '&' + config.method) {
      pending[p].cancel("request canceled");
      pending.splice(p, 1);
    }
  }
}
 // 添加請求攔截器
axios.interceptors.request.use(
  (config) => {
    removePending(config);
    config.cancelToken = new CancelToken((c) => {
      pending.push({ cancel: c, url: config.url + '&' + config.method });
    });
    return config;
  },
  (error) => {
    return Promise.reject(error);
  }
);
 // 響應(yīng)攔截器
axios.interceptors.response.use(
  (response) => {
    removePending(response.config);
    return response;
  },
  (error) => {
    return Promise.reject(error);
  }
);

在上面的代碼中,我們創(chuàng)建了一個請求隊列 pending ,然后為請求配置添加了一個 cancelToken ,并將其推入請求隊列中。在發(fā)送新的請求之前,我們遍歷請求隊列,將之前的所有請求都取消掉,并從請求隊列中移除。同時,我們還需要在響應(yīng)攔截器中將已經(jīng)完成的請求從請求隊列中移除。

需要注意的是,如果發(fā)送的請求是無法取消的,例如使用 jsonp 發(fā)送的請求,那么上面的代碼將無法取消這類請求。因此,我們需要根據(jù)實際情況選擇合適的方式來取消請求。

取消之后再次發(fā)送請求提示被cancel怎么辦?

如果在 axios 中取消了一個請求,那么再次發(fā)送同樣的請求會提示 Cancellation 已經(jīng)被取消的錯誤。這是因為 axios 同樣的請求已經(jīng)被 cancel ,因此無法再次發(fā)送。如果需要再次發(fā)送同樣的請求,需要重新創(chuàng)建一個新的 cancelToken ,否則會一直提示被取消。

下面是一個重新創(chuàng)建 cancelToken 的示例代碼:

import axios from 'axios';
let cancelToken = axios.CancelToken;
let cancel;
let config = {
  method: 'get',
  url: '/api/data',
  cancelToken: new cancelToken(function executor(c) {
    // executor 函數(shù)接收一個 cancel 函數(shù)作為參數(shù)
    cancel = c;
  })
};
// 添加請求攔截器
axios.interceptors.request.use(
  (config) => {
    // 如果 cancel 存在說明上次請求被取消了,重新創(chuàng)建一個
    if (typeof cancel === 'function') {
      config.cancelToken = new cancelToken(function executor(c) {
        cancel = c;
      });
    }
    return config;
  },
  (error) => {
    return Promise.reject(error);
  }
);
// 發(fā)送請求
axios(config)
  .then((response) => {
    console.log(response);
  })
  .catch((error) => {
    if (axios.isCancel(error)) {
      console.log('Request canceled', error.message);
    } else {
      console.log(error);
    }
  });
// 取消請求
cancel();

在上面的代碼中,我們在發(fā)送請求前先創(chuàng)建了一個 cancelToken ,并將 cancel 函數(shù)保存下來。當發(fā)送請求時,我們檢查 cancel 函數(shù)是否存在,如果存在說明上次請求被取消了,那么我們需要重新創(chuàng)建一個 cancelToken 并將其傳遞給新的請求中。這樣就可以在取消請求后重新發(fā)送同樣的請求了。

由于axios是對XHR對象的封裝,如果請求已經(jīng)被發(fā)送并且服務(wù)器已經(jīng)接收到請求,那么cancelToken 在調(diào)用 abort() 方法取消請求可能會導(dǎo)致一部分數(shù)據(jù)已經(jīng)被傳輸。因此,使用 時需要謹慎。

fetch請求才可以做到真正意義上的取消?。?!

總結(jié)

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

相關(guān)文章

  • 解決vue項目Error:Cannot find module‘xxx’類報錯問題

    解決vue項目Error:Cannot find module‘xxx’類報錯問題

    當npm運行報錯Error:Cannot find module 'xxx'時,通常是因為node_modules文件或依賴未正確安裝,解決步驟包括刪除node_modules和package-lock.json文件,重新運行npm install,并根據(jù)需要安裝額外插件,若網(wǎng)絡(luò)問題導(dǎo)致安裝失敗
    2024-10-10
  • vue實現(xiàn)表格動態(tài)嵌入折線圖的繪制代碼

    vue實現(xiàn)表格動態(tài)嵌入折線圖的繪制代碼

    這篇文章給大家介紹了vue實現(xiàn)表格動態(tài)嵌入折線圖的繪制方法,文中有詳細完整的代碼示例攻大家參考,對大家的學習或工作有一定的參考價值,需要的朋友可以參考下
    2023-10-10
  • vue項目中自定義video視頻控制條的實現(xiàn)代碼

    vue項目中自定義video視頻控制條的實現(xiàn)代碼

    這篇文章主要介紹了vue項目中自定義video視頻控制條的實現(xiàn)代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • vue?element-plus中el-input修改邊框border的方法

    vue?element-plus中el-input修改邊框border的方法

    element樣式還是蠻好的,只是有時候我們需要做一些調(diào)整,比如el-input的邊框,下面這篇文章主要給大家介紹了關(guān)于vue?element-plus中el-input修改邊框border的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)

    Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)

    這篇文章主要給大家介紹了關(guān)于Vue3 setup語法糖銷毀一個或多個定時器(setTimeout/setInterval)的相關(guān)資料,vue是單頁面應(yīng)用,路由切換后,定時器并不會自動關(guān)閉,需要手動清除,當頁面被銷毀時,清除定時器即可,需要的朋友可以參考下
    2023-10-10
  • vue3?父控件遠程獲取數(shù)據(jù)在子組件上顯示不出來的解決方案

    vue3?父控件遠程獲取數(shù)據(jù)在子組件上顯示不出來的解決方案

    這篇文章主要介紹了vue3?父控件遠程獲取數(shù)據(jù),在子組件上顯示不出來,本文給大家分享兩種解決方案幫助大家解決這個問題,需要的朋友可以參考下
    2023-08-08
  • vuejs路由的傳參及路由props配置詳解

    vuejs路由的傳參及路由props配置詳解

    最近在學習vue router的傳參,所以下面這篇文章主要給大家介紹了關(guān)于vuejs路由的傳參及路由props配置的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 在vue中axios設(shè)置timeout超時的操作

    在vue中axios設(shè)置timeout超時的操作

    這篇文章主要介紹了在vue中axios設(shè)置timeout超時的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 詳解vite+ts快速搭建vue3項目以及介紹相關(guān)特性

    詳解vite+ts快速搭建vue3項目以及介紹相關(guān)特性

    這篇文章主要介紹了vite+ts快速搭建vue3項目以及介紹相關(guān)特性,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • react和vue的事件處理差異詳解

    react和vue的事件處理差異詳解

    這篇文章主要介紹了react和vue的事件處理差異,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03

最新評論