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')
  }
}
相关推荐
cz追天之路18 小时前
华为机考--- 字符串最后一个单词的长度
javascript·css·华为·less
半桶水专家18 小时前
go语言中的结构体嵌入详解
开发语言·后端·golang
Light6018 小时前
CSS逻辑革命:原生if()函数如何重塑我们的样式编写思维
前端·css·响应式设计·组件化开发·css if函数·声明式ui·现代css
蜡笔小嘟19 小时前
宝塔安装dify,更新最新版本--代码版
前端·ai编程·dify
在屏幕前出油19 小时前
二、Python面向对象编程基础——理解self
开发语言·python
Irene199119 小时前
Vue:useSlots 和 useAttrs 深度解析
vue.js·useslots·useattrs
阿方索20 小时前
python文件与数据格式化
开发语言·python
ModyQyW20 小时前
HBuilderX 4.87 无法正常读取 macOS 环境配置的解决方案
前端·uni-app
bitbitDown20 小时前
我的2025年终总结
前端
五颜六色的黑20 小时前
vue3+elementPlus实现循环列表内容超出时展开收起功能
前端·javascript·vue.js