vue的axios取消请求

本文详细介绍了如何使用axios库中的CancelToken来取消HTTP请求,包括通过source工厂方法和executor函数创建CancelToken。重点讲解了在get和post请求中如何配置cancelToken,以及在请求被取消时如何捕获错误并显示取消原因。此外,还提醒了注意点,如请求取消时机和不同请求类型的cancelToken位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

axios取消请求

axios发送请求时,添加cancelToken配置项可以用于取消请求,cancelToken的取值有两种方式

1.使用 CancelToken.source 工厂方法创建cancel token

CancelToken有一个source静态方法,调用之后返回一个对象,该对象包含一个token属性用于标记请求和一个cancel方法用于取消请求

    const CancelToken = axios.CancelToken;
    const source = CancelToken.source();
     axios.get('http://localhost:6003/axios/4',{
        cancelToken: source.token
      }).then(function(res) {
            console.log(res.data);
          })
    source.cancel('不想请求了');

2.通过传递一个 executor 函数到 CancelToken 的构造函数创建cancel token

axios有一个CancelToken属性,他是一个类,用于获取取消请求的cancel方法,获取了该方法之后就可以在合适的地方执行cancel()取消请求了。这种方式比较麻烦,但是可以用于取消多个请求,你可以将c这个取消请求的方法push进一个数组,然后在你需要取消多个请求的时候,循环这个数组,依次执行里面的方法即可取消多个请求。

    let arr = [];
    const CancelToken = axios.CancelToken;
     axios.get('http://localhost:6003/axios/4',{
        cancelToken: new CancelToken(function executor(c){
            arr.push(c);
            //cancel = c;
        })
      }).then(function(res) {
            console.log(res.data);
          })
      axios.get('http://localhost:3000/axios/3',{
        cancelToken: new CancelToken(function executor(c){
            arr.push(c);
            //cancel = c;
        })
      }).then(function(res) {
            console.log(res.data);
          })
      for (let i = 0; i < arr.length; i++) {
        arr[i]('请求取消');
      }

注意点1:
cancel取消请求方法在调用取消请求的时候可以将取消原因——message字符串传递进去,这样请求在被取消之后会被catch捕获,你可以在这里将取消原因打印出来或者提示给用户,比如提示用户不要频繁点击发送请求

    const CancelToken = axios.CancelToken;
    const source = CancelToken.source();
     axios.get('http://localhost:6003/axios/4',{
        cancelToken: source.token
      }).then(function(res) {
            console.log(res.data);
          }).catch(function(err) {
            if (axios.isCancel(err)) {
              console.log(err.message);
            }
          })
      source.cancel('不想请求了');

注意点2:
get的cancelToken放置在第二个参数的对象里面,post的cancelToken放置在第三个参数对象里面

    const CancelToken = axios.CancelToken;
    const source = CancelToken.source();
    axios.post('http://localhost:6003/axios',{
                username: 'lisi',
                content: 123
            },{
                headers:{
                    "Content-Type": "application/json"
                 },
                 cancelToken: source.token
               }

               ).then(function(ret){
                console.log(ret.data);
            })
      source.cancel('不想请求了');
Vue 2中封装axios进行HTTP请求时,处理取消请求通常会涉及到`axios.CancelToken`。你可以创建一个`cancelTokenSource`,然后返回这个源的`token`,当需要取消请求时,通过调用`cancelTokenSource.cancel()`来停止请求。下面是一个简单的封装示例: ```javascript import axios from 'axios'; const service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, // api 的基础地址 timeout: 5000, // 请求超时时间 cancelToken: new axios.CancelToken((c) => { this.cancelRequest = c; // 将cancel函数绑定到组件实例上 }), }); service.interceptors.request.use( config => { if (!config.cancelToken) { config.cancelToken = this.cancelRequest; // 如果没有提供,则默认使用全局取消请求 } return config; }, error => Promise.reject(error) ); export default service; // 使用示例 this.$http.get('your-url').then(response => { // 请求成功... }).catch(error => { if (error.response && error.response.status === 401) { // 检查是否是因为取消请求导致的状态码 // 登录过期,重新登录... } else { console.error('Error:', error); } }).finally(() => { // 请求结束后的清理操作... }); // 要取消请求时,只需调用cancel方法 if (this.cancelRequest && !this.cancelled) { this.cancelRequest(); this.cancelled = true; } ``` 在这个例子中,当你需要取消请求时,可以在组件内调用`cancelRequest`。注意要保存一个标志`cancelled`来确认请求是否已经取消过,避免重复取消
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值