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')
  }
}
相关推荐
zfj3215 分钟前
CyclicBarrier、CountDownLatch、Semaphore 各自的作用和用法区别
java·开发语言·countdownlatch·semaphore·cyclicbarrier
张np12 分钟前
java基础-ConcurrentHashMap
java·开发语言
早日退休!!!13 分钟前
进程与线程的上下文加载_保存及内存映射
开发语言
jllllyuz14 分钟前
MATLAB实现蜻蜓优化算法
开发语言·算法·matlab
持续升级打怪中16 分钟前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化
GIS之路20 分钟前
GDAL 实现矢量合并
前端
hxjhnct22 分钟前
React useContext的缺陷
前端·react.js·前端框架
冰暮流星29 分钟前
javascript逻辑运算符
开发语言·javascript·ecmascript
flysh0530 分钟前
如何利用 C# 内置的 Action 和 Func 委托
开发语言·c#
前端 贾公子1 小时前
从入门到实践:前端 Monorepo 工程化实战(4)
前端