axios使用axiosSource.cancel取消请求后怎么恢复请求,axios取消请求和恢复请求实现

在前端做大文件分片上传,或者其它中断请求时,需要暂停或重新请求,比如这里大文件上传时,可能会需要暂停、继续上传,如下GIF演示:

这里不详细说文件上传的处理和切片细节,后续有时间在出一篇,大文件上传,切片上传、断点续传、秒传等😀。

不扯远了,紧接本篇主题😅。

如何使用axios取消请求

axios中已经实现了取消请求的操作,一共

  • 第一种 从 v0.22.0 开始,Axios 支持以 fetch API 方式------ AbortController 取消请求,示例如下
javascript 复制代码
import axios from 'axios';
const controller = new AbortController();
let fetchSignal = controller.signal
axios.post('http://www.***.cn/', {
   signal: fetchSignal
}).then((response)=> {
   //...
});

// 取消请求,不支持message参数
controller.abort()
  • 第二种 使用CancelToken.source工厂方法创建一个 cancel token ,如下所示:
javascript 复制代码
import axios from 'axios';
let axiosSource = axios.CancelToken.source();
	
axios({
  method: 'post',
  url: 'http://www.***.cn/',
  data: formdata,// 提交的文件数据或其它参数
  cancelToken: axiosSource.token,
  headers: { 'Content-Type': 'multipart/form-data' },
}).then((response)=> {
    //...
});

// 取消请求,支持message参数
axiosSource.cancel('取消请求');
  • 第三种 通过传递一个executor函数到CancelToken的构造函数来创建一个 cancel token,这里就不介绍了,可以查看官网示例🧐。

本文采用第二种方式实现。

如何重新发送请求

在重新发送请求前,需要重新生成CancelToken.source,不然再也无法从该URL获得成功的响应,因为同一个CancelToken.source都会被取消请求,如下图打印结果:

所以在重新请求前,需要重新生成一个CancelToken.source,代码如下:

javascript 复制代码
// 重新发送请求
axiosSource = axios.CancelToken.source();
axios({
//....代码同上
})

最后在放上axios官网的说明及实例链接 点我直达

如果本文对您有帮助,还请点个小赞😉。
本文完~

相关推荐
大尚来也5 分钟前
驾驭并发:.NET多线程编程的挑战与破局之道
java·前端·算法
快乐小土豆~~13 分钟前
echarts柱状图的X轴label过长被重叠覆盖
前端·javascript·vue.js·echarts
hhcccchh22 分钟前
1.1 HTML 语义化标签(header、nav、main、section、footer 等)
java·前端·html
小李子呢02111 小时前
前端八股2---Proxy 代理
前端·javascript·vue.js
bjzhang751 小时前
使用 HTML + JavaScript 实现组织架构图
前端·javascript·html·组织架构图
军军君011 小时前
Three.js基础功能学习十六:智能黑板实现实例三
前端·javascript·css·vue.js·3d·前端框架·threejs
海上彼尚1 小时前
SVG矢量图形快速入门
前端·html5
嗷o嗷o2 小时前
Android App Functions 深入理解
前端
qq_20815408852 小时前
瑞树6代流程分析
javascript·python
UXbot2 小时前
AI原型设计工具评测:从创意到交互式Demo,5款产品全面解析
前端·ui·设计模式·ai·ai编程·原型模式