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')
  }
}
相关推荐
乌拉那拉丹1 分钟前
vue3 配置跨域 (vite.config.ts中配置)
前端·vue.js
happymaker06264 分钟前
web前端学习日记——DAY01(HTML基本标签)
前端·学习·html
angerdream5 分钟前
最新版vue3+TypeScript开发入门到实战教程之DOM操作
javascript·vue.js
ECT-OS-JiuHuaShan6 分钟前
朱梁万有递归元定理,解构西方文明中心论幻觉
开发语言·人工智能·php
Aubrey-J7 分钟前
练习开发Skill——网页内容抓取Skill(website-content-fetch)
开发语言·人工智能
笨笨狗吞噬者8 分钟前
【uniapp】小程序支持分包引用分包 node_modules 依赖产物打包到分包中
前端·微信小程序·uni-app
handler0117 分钟前
基础算法:分治
c语言·开发语言·c++·笔记·学习·算法·深度优先
悟空瞎说18 分钟前
Electron 踩坑实录:主窗口 icon 配置了,打包 Windows 后死活不显示?(全网最细排查+解决方案)
前端
2501_9249526928 分钟前
设计模式在C++中的实现
开发语言·c++·算法
大傻^30 分钟前
LangChain4j 1.4.0 快速入门:JDK 11+ 基线迁移与首个 AI Service 构建
java·开发语言·人工智能