axios请求的取消

axios请求的取消

解决:axios请求的取消

在使用 Axios 发起请求时,有时候你可能需要取消这些请求,比如当组件销毁时或者用户操作导致不再需要获取之前发起的请求结果。Axios 支持通过 Cancel Token 取消请求。

以下是使用 Axios 的 CancelToken 来取消请求的基本步骤:

创建 Cancel Token:
首先你需要创建一个取消令牌(Cancel Token)。从 Axios 0.18.0 版本开始,推荐的方式是使用 axios.CancelToken.source() 工厂函数来创建一个包含 token 和 cancel 方法的对象。

const source = axios.CancelToken.source();

配置请求使用 Cancel Token:
在发起请求时,将上面创建的 token 传递给请求配置中的 cancelToken 字段。

axios.get('/user/12345', {
  cancelToken: source.token
})
.then(function(response) {
  // 处理成功情况
})
.catch(function(thrown) {
  if (axios.isCancel(thrown)) {
    console.log('Request canceled', thrown.message);
  } else {
    // 处理错误情况
  }
});

取消请求:
如果你想取消发起的请求,只需调用 source.cancel() 方法,并可以传入一个可选的取消原因作为参数。

source.cancel('用户取消了请求');

在 Vue 组件中管理取消逻辑(例如,在组件销毁前取消请求):

export default {
  data() {
    return {
      cancelSource: null,
    };
  },
  methods: {
    fetchData() {
      this.cancelSource = axios.CancelToken.source();

      axios.get('/someEndpoint', {
        cancelToken: this.cancelSource.token
      })
      .then(response => {
        // 处理响应数据
      })
      .catch(error => {
        if (axios.isCancel(error)) {
          console.log('Request canceled');
        } else {
          // 处理其他错误
        }
      });
    }
  },
  beforeDestroy() {
    if (this.cancelSource) {
      this.cancelSource.cancel('Component destroyed, request canceled.');
    }
  }
}

以上是在Vue 2 中使用 Axios 取消请求的方法。记得合理管理你的取消令牌,避免内存泄漏或其他潜在问题。

最后附上示例

  • 示例:在输入框里输入1234,会发送4次请求,但只会保留1个请求,其余的请求会被取消

接口处添加cancelToken

export function getERPInfoByDeviceCode(data, cancelToken) {
  return request({
    url: '/v1/dfs/deviceInfo/getERPInfoByDeviceCode',
    method: 'post',
    params: data,
    cancelToken, // 添加取消令牌
  })
}

使用取消请求

// 此处template代码为输入框绑定input事件给getERPInfoByDeviceCodeData()方法即可
<script>
import { getERPInfoByDeviceCode } from '@/api/standard/device-base-api'
import axios from 'axios'
export default {
  data() {
    return {
      cancelToken: null, // 保存取消令牌的引用
    }
  },
  methods: {
    async getERPInfoByDeviceCodeData() {
      // 如果存在之前的请求,取消它
      if (this.cancelToken) {
        this.cancelToken.cancel('用户取消了请求')
      }
      // 创建新的取消令牌
      const cancelTokenSource = axios.CancelToken.source()
      this.cancelToken = cancelTokenSource
      try {
        const params = {}
        // 请求接口传入cancelTokenSource.token配置
        await getERPInfoByDeviceCode(params, cancelTokenSource.token)
      } catch (error) {
        if (axios.isCancel(error)) {
          console.log('Request canceled:', error.message)
        } else {
          // 处理其他错误
          console.error('Error fetching info:', error)
        }
      }
    },
  },
}
</script>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Vue项目中,我们通常会使用axios来发送请求。为了方便管理和维护代码,我们可以将axios请求进行统一封装。 首先,我们需要在项目中安装axios: ``` npm install axios --save ``` 然后,我们可以在src目录下新建一个api目录,用来存放所有的接口请求。在api目录下,我们可以新建一个request.js文件,用来封装axios请求: ``` import axios from 'axios'; // 创建axios实例 const service = axios.create({ baseURL: process.env.BASE_API, // api的base_url timeout: 5000 // 请求超时时间 }); // request拦截器 service.interceptors.request.use(config => { // 在请求发送之前做一些处理 return config; }, error => { // 处理请求错误 console.log(error); Promise.reject(error); }) // respone拦截器 service.interceptors.response.use( response => { // 在接收响应做一些处理,例如统一的错误处理 return response.data; }, error => { console.log('err' + error);// for debug return Promise.reject(error); } ) export default service; ``` 这里我们创建了一个axios实例,并进行了一些配置,例如设置请求超时时间、拦截请求和响应等。并且将其导出,其他地方可以直接引用该实例进行请求。 接下来,我们可以在api目录下新建一个模块,例如user.js,用来存放用户相关的接口请求。在user.js中,我们可以这样写: ``` import request from '@/api/request'; export function login(username, password) { return request({ url: '/user/login', method: 'post', data: { username, password } }) } export function getInfo(token) { return request({ url: '/user/info', method: 'get', params: { token } }) } ``` 这里我们引入了之前封装的axios实例,然后对外导出两个方法login和getInfo,分别用来请求登录和获取用户信息的接口。 最后,我们可以在Vue组件中使用这些接口,例如: ``` import { login, getInfo } from '@/api/user'; export default { name: 'Login', methods: { handleLogin() { login(this.username, this.password).then(response => { // 处理登录成功的逻辑 getInfo(response.token).then(info => { // 处理获取用户信息成功的逻辑 }) }) } } } ``` 这里我们引入了之前定义的login和getInfo方法,并在handleLogin方法中调用它们。需要注意的是,我们在处理登录成功后,还调用了getInfo方法来获取用户信息。这里我们可以看到,我们可以将多个请求串联起来进行处理。 在实际开发中,我们经常会遇到重复请求的问题,例如多次点击提交按钮或者页面切换时进行数据加载等。为了避免重复请求,我们可以对axios进行进一步封装,例如: ``` import axios from 'axios'; // 定义一个空的数组,用来存储每个请求取消函数和标识 const pending = []; const CancelToken = axios.CancelToken; const removePending = (config) => { for (let i = 0; i < pending.length; i++) { if (pending[i].url === config.url + '&' + config.method) { pending[i].cancel(); // 取消重复请求 pending.splice(i, 1); // 删除已经取消请求记录 } } } // 创建axios实例 const service = axios.create({ baseURL: process.env.BASE_API, // api的base_url timeout: 5000 // 请求超时时间 }); // request拦截器 service.interceptors.request.use(config => { // 在请求发送之前做一些处理 removePending(config); config.cancelToken = new CancelToken((c) => { pending.push({ url: config.url + '&' + config.method, cancel: c }); }); return config; }, error => { // 处理请求错误 console.log(error); Promise.reject(error); }) // respone拦截器 service.interceptors.response.use( response => { // 在接收响应做一些处理,例如统一的错误处理 removePending(response.config); return response.data; }, error => { console.log('err' + error);// for debug return Promise.reject(error); } ) export default service; ``` 这里我们定义了一个pending数组,用来存储每个请求取消函数和标识。在每次请求发送之前,我们会先调用removePending函数,用来取消重复请求。在每次请求完成之后,我们会再次调用removePending函数,用来删除已经取消请求记录。这样就可以避免重复请求的问题了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码上暴富

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值