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')
  }
}
相关推荐
我是伪码农17 分钟前
外卖餐具智能推荐
linux·服务器·前端
qq_2837200519 分钟前
Python Celery + FastAPI + Vue 全栈异步任务实战
vue.js·python·fastapi
2401_8858850432 分钟前
营销推广短信接口集成:结合营销策略实现的API接口动态变量填充方案
前端·python
小李子呢021134 分钟前
前端八股性能优化(2)---回流(重排)和重绘
前端·javascript
zs宝来了35 分钟前
AQS详解
java·开发语言·jvm
程序员buddha1 小时前
深入理解ES6 Promise
前端·ecmascript·es6
吴声子夜歌1 小时前
ES6——Module详解
前端·ecmascript·es6
telllong1 小时前
Python异步编程从入门到不懵:asyncio实战踩坑7连发
开发语言·python
剪刀石头布啊2 小时前
原生form发起表单干了啥
前端
剪刀石头布啊2 小时前
表单校验场景,如何实现页面滚动到报错位置
前端