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')
  }
}
相关推荐
人道领域2 分钟前
JavaWeb从入门到进阶(javaScript)
开发语言·javascript·ecmascript
军军君014 分钟前
Three.js基础功能学习十二:常量与核心
前端·javascript·学习·3d·threejs·three·三维
chilavert31811 分钟前
技术演进中的开发沉思-317 JVM:指令集(下)
开发语言·python
m0_7482546627 分钟前
CSS AI 编程
前端·css·人工智能
不绝19131 分钟前
C#核心——面向对象:封装
开发语言·javascript·c#
yaoxin5211231 小时前
294. Java Stream API - 对流进行归约
java·开发语言
ghie90901 小时前
基于MATLAB的演化博弈仿真实现
开发语言·matlab
曹轲恒1 小时前
Thread.sleep() 方法详解
java·开发语言
aini_lovee1 小时前
基于Qt实现CAN通信上位机
开发语言·qt
27669582921 小时前
dy bd-ticket-guard-client-data bd-ticket-guard-ree-public-key 逆向
前端·javascript·python·abogus·bd-ticket·mstoken·ticket-guard