概述
import axios from "axios";
//pinia的仓库
import { GlobalStore } from "../stores";
// let globalStore = GlobalStore()
const config = {
baseURL: "http://127.0.0.1:3000",
timeout: 5000,
withCredentials: false
}
class RequestHttp {
service = null
constructor(config) {
this.service = axios.create(config)
/**
* @description 请求拦截器
* 客户端发送请求 -> [请求拦截器] -> 服务器
* token校验(JWT) : 接受服务器返回的token,存储到vuex/pinia/本地储存当中
*/
this.service.interceptors.request.use((config) => {
const globalStore = GlobalStore();
const token = globalStore.token;
return { ...config, headers: { ...config.headers, "x-access-token": token } }
}, (err) => {
return Promise.reject(error);
})
/**
* @description 响应拦截器
* 服务器换返回信息 -> [拦截统一处理] -> 客户端JS获取到信息
*/
this.service.interceptors.response.use(
(res) => {
const { data } = res
const globalStore = GlobalStore();
// if(data.code==200){
// }
return data
},
async (err) => {
return Promise.reject(err)
}
)
}
get(url, params = {}) {
return this.service.get(url, params)
}
post(url, params = {}) {
return this.service.post(url, params)
}
}
export default new RequestHttp(config)
最后
以上就是无奈故事为你收集整理的vue的axios封装的全部内容,希望文章能够帮你解决vue的axios封装所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复