Vue项目中Axios取消请求功能实现

1,封装axios实例 request.js

javascript 复制代码
const axios = require('axios');
 
// 创建一个axios实例
const service = axios.create({
  baseURL: "https://ip:port",
  timeout: 60000
});
 
export default service

2,封装请求 api.js

javascript 复制代码
import service from 'request'
import axios from "axios";

export const canCancelApi = (data, cancel) => {
    return service({
        url: '/api/test',
        method: 'post',
        data,
        cancelToken: new axios.CancelToken((c) => {
            cancel && cancel(c)
        })
    })
}

3,调用api

javascript 复制代码
import {onBeforeUnmount} from 'vue'
import {canCancelApi} from "api";


const apiCancel = null
// 通过回调接收caccel方法
canCancelApi(params, (cancle) => {
    apiCancel = cancle
  }).then(res => {})

onBeforeUnmount(() => {
  if(apiCancel){
    // 关闭页面时如果请求存在则取消请求
    apiCancel('custom-cancel')
  }
}
相关推荐
qq_3660862215 小时前
log.info中使用多个占位符{}问题
开发语言
大飞哥~BigFei15 小时前
新版chrome浏览器安全限制及解决办法
java·前端·chrome·安全·跨域
hepingfly15 小时前
SEO 如何寻找关键词?
前端
IT_陈寒15 小时前
SpringBoot 3.2实战:5个性能优化技巧让你的应用提速50%
前端·人工智能·后端
{Hello World}16 小时前
Java多态:三大条件与实现详解
java·开发语言
老蒋每日coding16 小时前
Java解析Excel并对特定内容做解析成功与否的颜色标记
java·开发语言·excel
lang2015092816 小时前
Java反射利器:Apache Commons BeanUtils详解
java·开发语言·apache
沐知全栈开发16 小时前
HTML DOM 方法
开发语言
扶苏100216 小时前
前端js高频面试点汇总
开发语言·前端·javascript
项目題供诗16 小时前
C语言基础(五)
c语言·开发语言