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')
  }
}
相关推荐
叫我小鹏呀3 分钟前
vue3中el-table中点击图片放大时,被表格覆盖
前端·javascript·vue.js
我命由我1234511 分钟前
2.使用 VSCode 过程中的英语积累 - Edit 菜单(每一次重点积累 5 个单词)
前端·javascript·ide·vscode·学习·编辑器·学习方法
四季予你6630 分钟前
vue2 和 vue3 的区别
前端·javascript·vue.js
自身就是太阳32 分钟前
Maven的高级特性
java·开发语言·数据库·后端·spring·maven
hakesashou38 分钟前
ruby和python哪个好学
开发语言·python·ruby
炒毛豆41 分钟前
vue3+ant design vue实现可编辑表格弹出气泡弹出窗~
前端·javascript·vue.js
寰宇软件41 分钟前
vue组件注册
前端·javascript·vue.js
林一怂儿43 分钟前
H5 three.js 实现六年级观察物体
开发语言·javascript
NiNg_1_2341 小时前
Python协程详解
开发语言·python