axios 如何取消请求

Axios 中提供了一个CanCelToken的函数,这是个构造函数,该函数的作用就是用来取消接口请求的,官方地址:

 

代码如下:

<template>
  <div>
    <el-button @click="startClick">
      开始请求
    </el-button>

    <br />
    <hr />

    <el-button @click="endClick">
      取消请求
    </el-button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      source: null, //存放取消的请求方法
    };
  },
  methods: {
    startClick() {
      this.getInfo();
    },
    endClick() {
      this.cancelQuest();
    },

    cancelQuest() {
      if (typeof this.source === "function") {
        this.source("终止请求"); //取消请求
      }
    },

    getInfo() {
      const _this = this;
      this.cancelQuest(); //在请求发出前取消上一次未完成的请求;
      //发送请求
      this.axios
        .get(`/test/data/check/updateExamRoom`, {
          cancelToken: new this.axios.CancelToken(function executor(c) {
            _this.source = c;
          }),
        })
        .then((res) => {
          //handle result
        })
        .catch((err) => {
          console.log(err);
          if (this.axios.isCancel(err)) {
            console.log("Rquest canceled", err.message); //请求如果被取消,这里是返回取消的message
          } else {
            //handle error
            console.log(err);
          }
        });
    },
  },
};
</script>

<style lang="scss"></style>

分析:主要是在发送axios请求时,再添加一个cancelToken的参数,它的值是一个构造函数;注意这个构造函数里面自带取消请求的函数,再我们需要取消请求的时候,调用这个函数即可(在请求的时候需要把这个函数给保存下来)

 

题外话:每个人的项目接口基本上都是封装好的,可根据不同的封装进行修改,把这个cancelToken参数添加进去就可以了,比如我的项目中接口在单独的js文件中

 

 

调用接口的时候传入这个cancelToken就行了,new this.axios.CancelToken(function executor(c) { that.source = c;  })  ,保存取消函数

 

 

 

 

 

取消的时候直接调用即可

 

 

 

posted @ 2021-08-09 09:32  静水思流  阅读(3402)  评论(0编辑  收藏  举报