網(wǎng)站首頁 編程語言 正文
一、原生ajax終止請(qǐng)求
1、abort()
? XMLHttpRequest.abort()
方法用于終止 XMLHttpRequest
對(duì)象的請(qǐng)求,該方法沒有參數(shù),也沒有返回值。當(dāng)調(diào)用該方法時(shí),如果對(duì)應(yīng) XMLHttpRequest
對(duì)象的請(qǐng)求已經(jīng)被發(fā)送并且正在處理中,則會(huì)中止該請(qǐng)求;如果請(qǐng)求已經(jīng)完成(即已經(jīng)接收到完整的響應(yīng)),則不會(huì)執(zhí)行任何操作。而且調(diào)用該方法后,還會(huì)觸發(fā) XMLHttpRequest
對(duì)象的abort
事件,我們可以在該事件的處理函數(shù)中執(zhí)行后續(xù)相關(guān)邏輯代碼,例如清除請(qǐng)求相關(guān)數(shù)據(jù)等等。
? 當(dāng)一個(gè)請(qǐng)求被終止后,該請(qǐng)求的readyState
將會(huì)變?yōu)?code>0,并且status
屬性也會(huì)變?yōu)?code>0。
案例代碼:
// 創(chuàng)建XMLHttpRequest對(duì)象
const xhr = new XMLHttpRequest();
// 請(qǐng)求地址
const url = "https://developer.mozilla.org/";
// 初始化請(qǐng)求
xhr.open('GET', url, true);
// 發(fā)送請(qǐng)求
xhr.send();
// 監(jiān)聽取消請(qǐng)求
xhr.addEventListener('abort', function () {
console.log('請(qǐng)求被abort()取消了');
});
// 定時(shí)器模擬取消請(qǐng)求
setTimeout(() => {
// 取消請(qǐng)求
xhr.abort();
// 取消請(qǐng)求之后的狀態(tài)status
console.log('abort()之后的xhr.status---', xhr.status);
// 取消請(qǐng)求之后的狀態(tài)readyState
console.log('abort()之后的xhr.readyState---', xhr.readyState);
}, 100);
執(zhí)行結(jié)果:
二、axios終止請(qǐng)求
1、AbortController(新版本)
? 在axiso
的0.22.0
版本開始,需要使用瀏覽器原生的AbortController
來終止請(qǐng)求,是目前推薦用的方法。當(dāng)使用該方法終止請(qǐng)求時(shí),如果對(duì)應(yīng)請(qǐng)求已經(jīng)被發(fā)送并且正在處理中,則會(huì)中止該請(qǐng)求;如果請(qǐng)求已經(jīng)完成(即已經(jīng)接收到完整的響應(yīng)),則不會(huì)執(zhí)行任何操作。
? 我們想監(jiān)聽到終止請(qǐng)求的操作,并進(jìn)行后續(xù)處理,有兩種方法:① 使用AbortController
提供的onabort
事件,通過監(jiān)聽該事件,并綁定事件處理函數(shù),在函數(shù)中進(jìn)行后續(xù)處理。② 使用try..catch
,終止請(qǐng)求之后,會(huì)觸發(fā)catch
,在catch
中進(jìn)行后續(xù)處理。如果同時(shí)使用onabort
事件和try..catch
,則會(huì)先觸發(fā)onabort
事件,再觸發(fā)try..catch
。
案例代碼:
// 以vue項(xiàng)目中使用axios為例
// 創(chuàng)建請(qǐng)求控制器
this.controller = new AbortController();
console.log("初始聲明的請(qǐng)求控制器------", this.controller);
// 第一種方法:綁定事件處理程序
this.controller.signal.addEventListener("abort", () => {
console.log("請(qǐng)求已終止,觸發(fā)了onabort事件");
// 進(jìn)行后續(xù)處理
});
// 第二種方法:try...catch
try {
// 發(fā)送文件上傳請(qǐng)求
const res = await this.$axios.post(api.Upload, uploadData, {
timeout: 0, // 設(shè)置超時(shí)時(shí)間為 0/null 表示永不超時(shí)
signal: this.controller.signal, // 綁定取消請(qǐng)求的信號(hào)量
});
} catch (error) {
console.log("終止請(qǐng)求時(shí)catch的error---", error);
// 判斷是否為取消上傳
if (error.message == "canceled"){
// 進(jìn)行后續(xù)處理
};
}
// 終止請(qǐng)求
this.controller.abort();
console.log("終止請(qǐng)求后的請(qǐng)求控制器------", this.controller);
執(zhí)行結(jié)果:
? 注意:每個(gè)AbortController
可以同時(shí)取消多個(gè)請(qǐng)求,但是只能取消請(qǐng)求一次,一個(gè)AbortController
在終止過請(qǐng)求之后,其控制是否終止請(qǐng)求的signal.aborted
屬性會(huì)從false
,變?yōu)?code>true,目前本人沒找到恢復(fù)為false
的方法,暫且認(rèn)為是不可恢復(fù)的吧。如果后續(xù)請(qǐng)求還是綁定該請(qǐng)求控制器,則后續(xù)請(qǐng)求都會(huì)被提前終止,不會(huì)被發(fā)出。
? 如果我們想要在終止請(qǐng)求之后,不影響后續(xù)請(qǐng)求的正常發(fā)出,且后續(xù)請(qǐng)求也是可以被終止的,那么需要在每次發(fā)出請(qǐng)求之前,都通過構(gòu)造函數(shù)創(chuàng)建一個(gè)新的的 AbortController
,每次請(qǐng)求綁定的都是新的AbortController
,這樣才能做到多次請(qǐng)求之間不干擾。
2、CancelToken(舊版本)
? 在axiso
的0.22.0
之前的版本,需要使用取消令牌cancel token
來終止請(qǐng)求,不過該API從0.22.0
開始被棄用,目前已不建議再使用。當(dāng)使用該方法終止請(qǐng)求時(shí),如果對(duì)應(yīng)請(qǐng)求已經(jīng)被發(fā)送并且正在處理中,則會(huì)中止該請(qǐng)求;如果請(qǐng)求已經(jīng)完成(即已經(jīng)接收到完整的響應(yīng)),則不會(huì)執(zhí)行任何操作。
? 該方法只能通過try..catch
來監(jiān)聽取消請(qǐng)求操作,終止請(qǐng)求之后,會(huì)觸發(fā)catch
,在catch
中進(jìn)行后續(xù)處理。而且該方法在取消請(qǐng)求時(shí),可以通過參數(shù)自定義catch
的error
中的message
內(nèi)容。
案例代碼:
// 以vue項(xiàng)目中使用axios為例
// 這個(gè)地方需要導(dǎo)入原生的axios 最好不要使用二次封裝后的axios
import axios from "axios";
// 創(chuàng)建請(qǐng)求令牌
this.source = axios.CancelToken.source();
console.log("初始聲明的請(qǐng)求令牌---", this.source);
// 第二種方法:try...catch
try {
// 發(fā)送文件上傳請(qǐng)求
const res = await this.$axios.post(api.Upload, uploadData, {
timeout: 0, // 設(shè)置超時(shí)時(shí)間為 0/null 表示永不超時(shí)
cancelToken: this.source.token, // 綁定取消請(qǐng)求的令牌
});
} catch (error) {
console.log("終止請(qǐng)求時(shí)catch的error---", error);
// 判斷是否為取消上傳
if (error.message == "自定義取消請(qǐng)求的message"){
// 進(jìn)行后續(xù)處理
};
}
// 終止請(qǐng)求
this.source.cancel("自定義取消請(qǐng)求的message");
console.log("取消請(qǐng)求后的請(qǐng)求令牌---", this.source);
執(zhí)行結(jié)果:
? 注意:該方法與AbortController
相同,都可以同時(shí)取消多個(gè)請(qǐng)求,但是只能取消請(qǐng)求一次,一個(gè)CancelToken
在終止過請(qǐng)求之后,如果后續(xù)請(qǐng)求還是綁定該請(qǐng)求令牌,則后續(xù)請(qǐng)求都會(huì)被提前終止,不會(huì)被發(fā)出。
? 同理,如果我們想要在終止請(qǐng)求之后,不影響后續(xù)請(qǐng)求的正常發(fā)出,且后續(xù)請(qǐng)求也是可以被終止的,那么需要在每次發(fā)出請(qǐng)求之前,都創(chuàng)建一個(gè)新的的 CancelToken
,每次請(qǐng)求綁定的都是新的CancelToken
,這樣才能做到多次請(qǐng)求之間不干擾。
三、參考資料
Axios中文文檔
AbortController
XMLHttpRequest.abort()
原文鏈接:https://blog.csdn.net/weixin_45092437/article/details/131211952
- 上一篇:沒有了
- 下一篇:沒有了
相關(guān)推薦
- 2022-08-20 在python中讀取和寫入CSV文件詳情_python
- 2022-04-19 前端開發(fā)中幾種存儲(chǔ)方式詳解
- 2022-08-31 docker(alpine+golang)?中?hosts?不生效問題解決方法_docker
- 2022-10-19 Beego?AutoRouter工作原理解析_Golang
- 2022-04-02 Docker部署Nginx并配置反向代理_docker
- 2022-06-01 Python?調(diào)用?C++?傳遞numpy?數(shù)據(jù)詳情_python
- 2022-04-18 Android實(shí)現(xiàn)繪制折線圖APP代碼_Android
- 2022-04-27 Python中python-nmap模塊的使用介紹_python
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支