精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Axios如何取消請求,其原理是什么?

開發 前端
Axios 取消請求的原理是基于底層網絡請求庫(如 XMLHttpRequest 或 Fetch)提供的中止機制。當調用取消令牌的 cancel 方法時,Axios 會觸發中止底層的網絡請求,從而終止正在進行的請求過程。

axios 可以通過創建一個 CancelToken 來取消一個請求,基本原理是:

  1. 創建一個 CancelToken 的實例,它有一個 executor 函數,可以通過調用 executor 參數中的 cancel 函數來取消請求。
  2. 在 axios 請求配置中指定 cancelToken 屬性,將 CancelToken 實例傳遞進去。
  3. 當我們需要取消請求時,調用 CancelToken 實例的 cancel() 方法即可取消對應的請求。
  4. axios 檢測到配置的 cancelToken 被取消,就會取消掉這個請求,并在錯誤回調中返回一個 Cancel 錯誤。axios 內部會監聽 cancelToken 實例的 cancel 信號,一旦觸發就會跳出隊列,取消對應請求的執行。示例代碼:
js
const CancelToken = axios.CancelToken;
const source = CancelToken.source();


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


// 取消請求
source.cancel('Operation canceled by the user.');

vue、React項目中如何取消

在基于 React 或 Vue 的應用中,可以通過封裝 Axios 并結合組件的狀態管理來實現取消請求的功能。下面分別介紹在 React 和 Vue 中如何實現這一點。

在 React 中的實現:

  1. 創建一個封裝的 Axios 實例,以便于應用中的多個組件共享相同的配置和取消令牌。
// axiosInstance.js
import axios from 'axios';


const instance = axios.create();


export default instance;
  1. 在組件中使用這個封裝的 Axios 實例,并結合組件的狀態管理來處理取消請求的邏輯。
// YourComponent.js
import React, { useState } from 'react';
import axiosInstance from './axiosInstance';


function YourComponent() {
  const [loading, setLoading] = useState(false);
  const [data, setData] = useState(null);


  const source = axiosInstance.CancelToken.source();


  const fetchData = async () => {
    try {
      setLoading(true);
      const response = await axiosInstance.get('/api/some-endpoint', {
        cancelToken: source.token
      });
      setData(response.data);
      setLoading(false);
    } catch (error) {
      if (axiosInstance.isCancel(error)) {
        console.log('請求被取消:', error.message);
      } else {
        // 處理其他錯誤
      }
      setLoading(false);
    }
  };


  const cancelRequest = () => {
    source.cancel('請求被用戶取消');
  };


  return (
    <div>
      {loading ? <p>Loading...</p> : <p>{data}</p>}
      <button onClick={fetchData}>Fetch Data</button>
      <button onClick={cancelRequest}>取消請求</button>
    </div>
  );
}


export default YourComponent;

在 Vue 中的實現:

  1. 創建一個封裝的 Axios 實例,同樣可以讓多個組件共享相同的配置和取消令牌。
// axiosInstance.js
import axios from 'axios';


const instance = axios.create();


export default instance;
  1. 在組件中使用這個封裝的 Axios 實例,并結合組件的狀態管理來處理取消請求的邏輯。
<template>
  <div>
    <p v-if="loading">Loading...</p>
    <p v-else>{{ data }}</p>
    <button @click="fetchData">Fetch Data</button>
    <button @click="cancelRequest">取消請求</button>
  </div>
</template>


<script>
import axiosInstance from './axiosInstance';


export default {
  data() {
    return {
      loading: false,
      data: null,
      source: axiosInstance.CancelToken.source()
    };
  },
  methods: {
    async fetchData() {
      try {
        this.loading = true;
        const response = await axiosInstance.get('/api/some-endpoint', {
          cancelToken: this.source.token
        });
        this.data = response.data;
        this.loading = false;
      } catch (error) {
        if (axiosInstance.isCancel(error)) {
          console.log('請求被取消:', error.message);
        } else {
          // 處理其他錯誤
        }
        this.loading = false;
      }
    },
    cancelRequest() {
      this.source.cancel('請求被用戶取消');
    }
  }
};
</script>

原理

Axios 取消請求的原理是基于底層網絡請求庫(如 XMLHttpRequest 或 Fetch)提供的中止機制。當調用取消令牌的 cancel 方法時,Axios 會觸發中止底層的網絡請求,從而終止正在進行的請求過程。

具體來說,以下是 Axios 取消請求的原理:

  1. 創建 CancelToken 對象: 在發起請求之前,可以通過 axios.CancelToken.source() 方法創建一個 CancelToken 對象,并獲取其中的 token。這個 token 是一個用于標識該請求的令牌。
  2. 關聯 CancelToken: 將創建的 CancelToken 對象中的 token 關聯到請求的配置中,通過 cancelToken 參數。這告訴 Axios 在取消令牌觸發時要取消這個請求。
  3. 取消請求: 當想要取消請求時,調用 CancelToken 對象中的 cancel 方法,并提供一個取消的原因。這會觸發 Axios 內部的邏輯,導致底層的網絡請求被中止。
  4. 捕獲取消錯誤: 如果請求在取消前已經發出,Axios 會拋出一個名為 Cancel 的錯誤。可以使用 axios.isCancel(error) 來檢查是否是取消錯誤。在 .catch 部分處理這個取消錯誤。

底層 XMLHttpRequest 和 Fetch API 都提供了終止請求的機制。當取消請求時,Axios 會調用底層網絡請求的相應中止方法,例如 xhr.abort() 或 fetch.abort(),從而使網絡請求停止并拋出取消錯誤。這個機制允許有效地取消正在進行的請求,避免不必要的數據傳輸和處理。

責任編輯:武曉燕 來源: 海燕技術棧
相關推薦

2024-08-27 08:55:32

Axios底層網絡

2021-04-06 06:01:11

AxiosWeb 項目開發

2021-04-22 05:37:14

Axios 開源項目HTTP 攔截器

2025-10-16 09:08:03

2012-02-15 14:12:58

開源軟件政府

2021-04-12 05:55:29

緩存數據Axios

2021-07-27 14:50:15

axiosHTTP前端

2018-11-26 14:55:33

固態硬盤SSD選購

2025-01-15 13:30:48

FeignHTTPJava

2023-11-05 10:52:54

DNS服務器瀏覽器

2024-06-05 08:42:24

2018-06-14 10:32:25

2021-10-21 09:40:50

AI人工智能

2021-12-09 17:14:05

戴爾

2024-11-25 12:20:00

Hystrix微服務架構

2021-09-10 06:50:03

HashMapHash方法

2019-08-14 14:56:52

無服務器云原生FaaS

2020-12-03 08:14:45

Axios核心Promise

2021-09-27 08:02:17

CDN加速網站網絡

2024-01-11 08:53:58

點贊
收藏

51CTO技術棧公眾號

国产成人在线影院 | 91成人免费网站| 日韩影片在线播放| 在线观看中文字幕视频| 97一区二区国产好的精华液| 一本色道久久加勒比精品| 亚洲午夜精品久久| 人妻视频一区二区三区| 免费看欧美美女黄的网站| 欧美久久精品午夜青青大伊人| 中文字幕免费在线播放| 精品国产黄a∨片高清在线| 亚洲国产精品欧美一二99| 奇米影视首页 狠狠色丁香婷婷久久综合 | 福利二区91精品bt7086| 亚洲不卡1区| 午夜精品久久久久久久99老熟妇| 久久一区激情| 久久久久久国产免费| 久久免费手机视频| 日韩电影不卡一区| 欧美电影免费提供在线观看| 美女网站免费观看视频| brazzers在线观看| 中文字幕一区二区三区乱码在线| 快播日韩欧美| 色综合免费视频| 国产福利一区二区| 成人网在线免费观看| 黄色av网站免费观看| 亚洲国产激情| 久久手机免费视频| www.涩涩爱| 国产精品免费不| 亚洲精品白浆高清久久久久久| 永久av免费在线观看| 精品久久99| 欧美亚洲动漫精品| 可以免费在线看黄的网站| h片在线观看视频免费免费| 亚洲精品水蜜桃| 伊人久久大香线蕉精品| youjizz在线播放| 久久久久88色偷偷免费| 久久影院理伦片| 亚洲三区在线播放| 99久久精品国产一区| 国产精品久久久久久久久久久久冷| 国产精品人人爽| 乱一区二区av| 成人精品久久av网站| 中文字幕欧美色图| 蜜桃av一区二区三区| 国产精品爽爽ⅴa在线观看| 久久精品视频2| 日日摸夜夜添夜夜添国产精品| 欧美综合在线观看| 黄色片中文字幕| 天堂影院一区二区| 国产精品久久久久久av福利| 99re国产在线| 久久er精品视频| 亚洲aaa激情| 成 人 免费 黄 色| 99re这里都是精品| 欧美亚洲另类久久综合| 大地资源中文在线观看免费版 | 自拍偷拍第9页| 欧美国产一级| 欧美肥婆姓交大片| 男女啊啊啊视频| 久久综合影视| 91精品视频免费观看| 亚洲乱熟女一区二区| 99精品视频免费在线观看| 欧美日韩一区在线观看视频| 日本不卡三区| 亚洲综合丝袜美腿| 日韩手机在线观看视频| 久久亚洲人体| 精品剧情在线观看| 美女脱光内衣内裤| 国产精品毛片久久| 久久免费少妇高潮久久精品99| 五月婷婷开心网| 久久精品免费看| 99久久综合狠狠综合久久止 | 久久久久亚洲蜜桃| 亚洲综合首页| 啊啊啊久久久| 欧美三级三级三级| 亚洲欧美日韩色| 成人女性视频| 久久久久久免费精品| 久久久久久久久黄色| 韩国三级电影一区二区| 国产一区免费观看| 亚洲搞黄视频| 狠狠干狠狠久久| 天美一区二区三区| 欧美精美视频| 欧美福利视频网站| 国产精品xxxxxx| 丁香啪啪综合成人亚洲小说 | 欧美日韩和欧美的一区二区| 99免费观看视频| 日本久久黄色| 欧美亚洲国产成人精品| 国产av无码专区亚洲av| 国产欧美一区二区在线| 男女激情免费视频| 成人黄色91| 国产午夜精品一区二区三区 | 亚洲人成高清| 成人春色激情网| 欧美黄色小说| 亚瑟在线精品视频| 污视频在线观看免费网站| 精品日韩在线| 韩剧1988在线观看免费完整版| 亚洲一级特黄毛片| 久久九九全国免费| 男人添女荫道口图片| 欧一区二区三区| 色婷婷久久av| 涩涩视频在线观看| 久久色视频免费观看| www插插插无码视频网站| 成人在线精品| 色妞欧美日韩在线| 伊人免费在线观看高清版| 91在线你懂得| 久久网站免费视频| 婷婷成人综合| 欧美在线www| 亚洲色图欧美视频| 亚洲第一成年网| 在线观看免费视频黄| 狠狠干成人综合网| 成人黄色片视频网站| 尤物视频在线看| 欧美一级日韩一级| 欧美另类videoxo高潮| 国产真实乱偷精品视频免| 亚洲精品视频一二三| 日韩制服诱惑| 伊人久久久久久久久久久| 免费视频网站在线观看入口| 久久久国产一区二区三区四区小说 | 日本中文字幕一区二区有限公司| 欧美自拍资源在线| 免费在线成人激情电影| 永久免费精品影视网站| 日韩av免费播放| 国产精品色婷婷| 午夜一区二区视频| 久久久9色精品国产一区二区三区| 国产热re99久久6国产精品| 日日夜夜精品一区| 日韩欧美国产三级电影视频| 久久精品www人人爽人人| 色天天综合色天天久久| 男女啪啪的视频| 97色婷婷成人综合在线观看| 日韩一区二区福利| 国产精品国产精品国产专区| 18欧美乱大交hd1984| 欧美性猛交xx| 一区在线视频| 欧美在线一区二区三区四区| 国产精品77777竹菊影视小说| **亚洲第一综合导航网站| free性欧美hd另类精品| 精品久久国产字幕高潮| 国产无码精品在线观看| wwwwww.欧美系列| 91最新在线观看| 亚洲色图欧美| 精品国产一二| 欧美视频第一| 欧美精品videos| 国产一二三区在线视频| 91精品国产麻豆| 久久久久久久久久影院| 中文字幕一区二区三中文字幕| 亚洲欧洲国产视频| 日韩电影免费在线观看网站| 国产小视频免费| 色综合综合网| 99在线影院| 日韩一区精品| 久久久天堂国产精品女人| 国产在线观看精品一区| 日韩午夜中文字幕| 波多野结衣一区二区三区在线| 亚洲免费高清视频在线| 黄瓜视频污在线观看| 国产精品综合av一区二区国产馆| 免费看又黄又无码的网站| 国产精品久久久久久影院8一贰佰 国产精品久久久久久麻豆一区软件 | 色网站国产精品| 校园春色 亚洲| 国产欧美一区视频| 久久久久亚洲AV成人无码国产| 蜜桃av一区二区在线观看| 分分操这里只有精品| 午夜影院欧美| 欧美日韩国产一二| 中文字幕亚洲在线观看| 国产精品免费一区豆花| 2020国产在线| 欧美乱妇40p| 五月天婷婷在线视频| 日韩电影网在线| 亚洲第一页在线观看| 欧美日韩国产首页在线观看| 五月天综合激情网| 一区二区激情视频| 永久久久久久久| 国产精品免费丝袜| 精品无码国产污污污免费网站 | 欧美人与牲禽动交com| 一区二区国产精品视频| 无码国产伦一区二区三区视频| 欧美一区二区精品| 91中文字幕在线播放| 欧美曰成人黄网| 国产剧情在线视频| 欧美日韩中文字幕| 日韩欧美国产亚洲| 污片在线观看一区二区| 久草成人在线视频| 一区二区国产视频| 久久久一区二区三区四区| 亚洲黄色av一区| 亚洲熟女www一区二区三区| 中文字幕一区二区三区精华液| 91麻豆制片厂| 中文字幕电影一区| 五月激情四射婷婷| 国产精品日日摸夜夜摸av| av手机在线播放| 国产色产综合产在线视频| 一区二区伦理片| 亚洲国产岛国毛片在线| 性の欲びの女javhd| 日韩亚洲视频在线观看| 欧日韩不卡视频| 波多野结衣在线aⅴ中文字幕不卡| 992tv人人草| 国产河南妇女毛片精品久久久| 午夜啪啪小视频| 国产精品一二二区| 麻豆短视频在线观看| 成人av资源网站| 国产精品伦子伦| 国产亚洲va综合人人澡精品| 亚洲av熟女国产一区二区性色| 国产a亚洲精品| 91大神在线播放精品| 亚洲电影观看| 国产成人综合精品在线| 中文另类视频| 国产精品自拍网| 精品伊人久久| 国产伦精品一区二区三区| 日韩aaa久久蜜桃av| 欧洲高清一区二区| 久久精品亚洲人成影院| 欧美一级片免费播放| 久久久久久久高潮| 婷婷中文字幕在线观看| 懂色av噜噜一区二区三区av| 五十路六十路七十路熟婆| 国产亚洲婷婷免费| 天天看片中文字幕| 精品欧美一区二区三区| 中文字幕福利视频| 欧美成人精品1314www| 男同在线观看| 久久大大胆人体| 咪咪网在线视频| 国产精品久久久久久久久久三级 | 成人黄色在线电影| 97热精品视频官网| 国产一区影院| 国产手机精品在线| 欧美激情777| 玩弄中年熟妇正在播放| 日韩av网站在线观看| 日本中文字幕精品| 国产情人综合久久777777| 午夜国产福利一区二区| 欧美性精品220| a天堂在线观看视频| 亚洲日韩欧美视频一区| 亚洲精品白浆| 国产免费一区视频观看免费 | 精品国产乱码久久久久久图片| 国产主播福利在线| 久久久免费精品| 粉嫩av国产一区二区三区| 久久久久久精| 狠狠色狠狠色综合日日tαg| 国产wwwxx| 91理论电影在线观看| 激情综合五月网| 这里只有精品视频在线观看| 国产鲁鲁视频在线观看免费| 欧美精品电影在线| 九九久久国产| 欧美一区二视频在线免费观看| 欧美日本亚洲韩国国产| 亚洲天堂国产视频| 久久久国产精品不卡| 日本一区二区三区免费视频| 337p亚洲精品色噜噜噜| 成人亚洲综合天堂| 欧美中文在线观看国产| 风间由美性色一区二区三区四区| 国产又大又长又粗又黄| 蜜臀久久99精品久久久久宅男| 国产偷人妻精品一区| 亚洲国产欧美日韩另类综合| 99热这里只有精| 久久精品国产亚洲7777| 久久女人天堂| 欧美少妇一区| 丝袜诱惑制服诱惑色一区在线观看 | 99在线热播精品免费| 久久久精品视频在线| 日韩天堂在线观看| av片在线观看永久免费| 成人激情视频免费在线| 成人激情电影在线| www.超碰com| 国产精品污网站| 亚洲 小说区 图片区| 一区二区三区亚洲| 日韩制服诱惑| 在线国产精品网| 精品一二三四区| 九九精品视频免费| 欧美一区中文字幕| 怡红院av在线| 国产v亚洲v天堂无码| 国内精品久久久久久久97牛牛 | 黄色av小说在线观看| 欧美xxxx做受欧美.88| 国产一区二区av在线| 五月天在线免费视频| 国产一区二区三区综合| 欧美成人一区二区三区高清| 亚洲精品在线电影| 超碰91在线观看| 欧美精品一区在线发布| 媚黑女一区二区| 亚洲毛片亚洲毛片亚洲毛片| 欧美精品日韩一区| 手机电影在线观看| 精品国产乱码久久久久久108| 亚洲尤物在线| 欧美另类69xxxx| 日韩一区二区三区电影| а√天堂资源官网在线资源| 日本不卡一区二区三区在线观看| 久久激五月天综合精品| 黄色一级免费视频| 国产丝袜高跟一区| 成人国产综合| 久久久99精品视频| 久久亚区不卡日本| 亚洲香蕉在线视频| 欧美精品久久久久久久免费观看 | 亚洲免费视频在线观看| 久久青草视频| 欧美不卡在线播放| 欧美国产综合色视频| 国产黄a三级三级看三级| 91av国产在线| 99久久综合| 亚洲精品乱码久久| 欧美日韩成人在线| 黄页在线观看免费| 日韩欧美视频第二区| 国产成人免费在线视频| 免费av中文字幕| 九色精品免费永久在线| 神马影视一区二区| 亚洲av无码成人精品区| 在线精品观看国产| 久久www人成免费看片中文| 欧美日韩在线精品| 成人综合激情网| 在线免费观看一区二区| 97精品久久久| 综合天堂久久久久久久| 色欲av无码一区二区三区| 日韩欧美精品在线| 亚洲电影有码|