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')
  }
}
相关推荐
Laughtin1 天前
macos的python安装选择以及homebrew python的安装方法
开发语言·python·macos
java1234_小锋1 天前
分享一套优质的SpringBoot4+Vue3学生信息管理系统
java·vue.js·spring boot·学生信息
默凉1 天前
C++ 编译过程
开发语言·c++
csbysj20201 天前
C 标准库 - `<errno.h>`
开发语言
Highcharts.js1 天前
Highcharts 3D漏斗图(Funnel 3D)完全指南:从模块加载到一文学会三维漏斗可视化
javascript·开发文档·highcharts·图表开发·漏斗图·3d 图表
人道领域1 天前
Maven多模块开发:高效构建复杂项目
java·开发语言·spring boot·maven
FunW1n1 天前
TMF框架与Frida脚本相关疑问及核心解析提炼
开发语言·网络·python
ArturiaZ1 天前
【day28】
开发语言·c++·算法
myFirstName1 天前
离谱!React中不起眼的[]和{}居然也会导致性能问题
前端
我是伪码农1 天前
Vue 2.11
前端·javascript·vue.js