axios封装apis.js
import axios from 'axios'
import { Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'
// 创建axios实例
const service = axios.create({
baseURL: process.env.BASE_API, // api的base_url
timeout: 5000 // 请求超时时间
})
// request拦截器
service.interceptors.request.use(config => {
if (store.getters.token) {
// 让每个请求携带token--['X-Token']为自定义key 请根据实际情况自行修改
config.headers['X-Token'] = getToken()
}
return config
}, error => {
//错误
console.log(error)
Promise.reject(error)
})
// respone拦截器
service.interceptors.response.use(
response => response,
// 根据res.code编码判断
// const res = response.data;
// if (res.code !== 20000) {
// //判断
// if (res.code === 50008 || res.code === 50012 || res.code === 50014) {
// // 50008:非法的token; 50012:其他客户端登录了; 50014:Token 过期了;
// }
// return Promise.reject('error');
// } else {
// return response.data;
// }
error => {
//错误
Message({
message: error.message,
type: 'error',
duration: 3000
})
return Promise.reject(error)
})
export default service
模版调用
import request from '@/utils/apis'
//使用
export function getInfo(params) {
return request({
url: '/user/list',
method: 'get',
params
});
}
以上是编程学习网小编为您介绍的“结合vuex封装axios方法”的全面内容,想了解更多关于 vuejs 内容,请继续关注编程基础学习网。
沃梦达教程
本文标题为:结合vuex封装axios方法


基础教程推荐
猜你喜欢
- html5视频如何嵌入到网页(视频代码) 2025-01-22
- 纯css实现漂亮又健壮的tooltip的方法 2024-01-23
- JSONObject与JSONArray使用方法解析 2024-02-07
- Loaders.css免费开源加载动画框架介绍 2025-01-23
- js判断一个对象是否在一个对象数组中(场景分析) 2022-10-21
- Django操作cookie的实现 2024-04-15
- 创建Vue3.0需要安装哪些脚手架 2025-01-16
- clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析 2024-01-08
- Bootstrap学习笔记之css组件(3) 2024-01-22
- webpack学习笔记一:安装webpack、webpack-dev-server、内存加载js和html文件、loader处理非js文件 2023-10-29