vue项目中axios统一或单独控制接口请求时间

先说统一

这里将请求时间统一控制在12秒

javascript 复制代码
// 使用由库提供的配置的默认值来创建实例
// 此时超时配置的默认值是 `0`
const axiosInstance = axios.create()

// 覆写库的超时默认值
// 现在,在超时前,所有请求时间统一控制在10秒
axiosInstance.defaults.timeout = 1000 * 10

单独控制

上传文件的时候,文件一旦大一些,就会超过设置的时间,出现接口连接超时的问题,所以我们需要单独为上传接口设置一个请求超时时间

在instance.interceptors.request.use() 下的config中 添加上一个判断后请求时间赋值即可

javascript 复制代码
axiosInstance.interceptors.request.use(
  config => {
    config.headers.common['Authorization'] = localStorage.getItem('token')
    if(config.url.indexOf('upload/file') > -1){ 
      config.timeout = 1000 * 1800
    }
    return config
  },
  err => {
    console.log(err) // for debug
    return Promise.reject(err)
  }
)

以上就可以满足使用默认上传时单独配置请求时间


补充(非上传接口等写法):

javascript 复制代码
// 统一配置默认超时时间:
const axiosInstance = axios.create();//创建实例
let Config = {
	TIMEOUT: 6000,//设置超时时间为6秒
};
axiosInstance .defaults.timeout = Config.TIMEOUT;

// 默认请求时间接口请求:
export function newTaskAdd(data) {
  return request({
    url: '/api/taskPlan/add',
    method: 'post',
    data
  })
}

// 重设超时时间的接口请求:
export function newTaskAdd(data) {
  return request({
    url: '/api/taskPlan/add',
    method: 'post',
    timeout: 60 * 60 * 1000,
    data
  })
}
相关推荐
智算菩萨4 分钟前
实战:高级中文自然语言处理系统的Python设计与实现
前端·javascript·easyui
q_19132846956 分钟前
基于SpringBoot2+Vue2的诗词文化传播平台
vue.js·spring boot·mysql·程序员·计算机毕业设计
远山无期26 分钟前
解决Tailwind任意值滥用:规范化CSS开发体验
前端·css·eslint
用户542778485154035 分钟前
Vue 3 中开发高阶组件(HOC)与 Renderless 组件
前端
幼儿园老大44 分钟前
告别代码屎山!UniApp + Vue3 自动化规范:ESLint 9+ 扁平化配置全指南
javascript·vue.js
HIT_Weston1 小时前
67、【Ubuntu】【Hugo】搭建私人博客(一)
前端·ubuntu·hugo
阿里巴啦1 小时前
用React+Three.js 做 3D Web版搭建三维交互场景:模型的可视化摆放与轻量交互
前端·react·three.js·模型可视化·web三维·web三维交互场景
daols881 小时前
vue 甘特图 vxe-gantt table 连接线的用法详解
vue.js·甘特图·vxe-table
Liu.7741 小时前
vue3组件之间传输数据
前端·javascript·vue.js
|晴 天|1 小时前
前端闭包:从概念到实战,解锁JavaScript高级技能
开发语言·前端·javascript