前端面试:axios 是否可以取消请求?

在实际工作中,取消请求的场景通常出现在以下几种情况中:

  1. 用户导航离开页面:如果用户在请求数据的过程中快速切换到另一个页面,可以通过取消未完成的请求来优化性能。
  2. 输入框的搜索提示:当用户在输入框中输入内容时,可以结合防抖的方式取消之前的请求,从而只保留最新的请求,避免发送过多的请求。

取消请求的实现方式

Axios 提供了 CancelToken 的功能来实现请求的取消。以下是具体的代码示例:

复制代码
import axios from 'axios';  

// 创建一个取消源  
const CancelToken = axios.CancelToken;  
let cancel;  

// 发送请求时可以传入 cancel token  
axios.get('/api/data', {  
  cancelToken: new CancelToken(function executor(c) {  
    // 这里可以保存对 cancel 的引用  
    cancel = c;  
  })  
}).then(response => {  
  console.log(response.data);  
}).catch(error => {  
  if (axios.isCancel(error)) {  
    console.log('请求已被取消', error.message);  
  } else {  
    // 处理其他错误  
    console.error('请求出错', error);  
  }  
});  

// 需要取消请求时调用 cancel  
cancel('请求被用户取消');  

注意:

  1. 仅在需要取消请求的情况下调用 cancel 函数。
  2. 取消请求的异常会被 catch 捕获,通过 axios.isCancel 来判断是否是取消的原因。
  3. 记得根据实际需求合理使用取消请求的功能,以避免不必要的请求和资源浪费
相关推荐
Yvonne爱编码17 小时前
AJAX入门-AJAX 概念和 axios 使用
前端·javascript·ajax·html·js
在路上`18 小时前
前端学习之后端java小白(三)-sql外键约束一对多
java·前端·学习
Pu_Nine_918 小时前
10 分钟上手 ECharts:从“能跑”到“生产级”的完整踩坑之旅
前端·javascript·echarts·css3·html5
東雪蓮☆19 小时前
从零开始掌握 Web 与 Nginx:入门详解
运维·服务器·前端·nginx
脑子慢且灵19 小时前
【JavaWeb】一个简单的Web浏览服务程序
java·前端·后端·servlet·tomcat·web·javaee
柯南二号19 小时前
【大前端】 断点续传 + 分片上传(大文件上传优化) 的前端示例
前端
前端小超超19 小时前
如何配置capacitor 打包的安卓app固定竖屏展示?
android·前端·gitee
xiaopengbc20 小时前
在Webpack中,如何在不同环境中使用不同的API地址?
前端·webpack·node.js
前端AK君20 小时前
React中台系统如何嵌入到业务系统中
前端
Slice_cy20 小时前
不定高虚拟列表
前端