//store.js
import Vue from 'vue'
import Vuex from 'vuex'
import createPersistedState from 'vuex-persistedstate'
import axios from 'axios'
//拦截器
axios.interceptors.request.use(function (config) {
//从vuex用户信息中获取token
const token = JSON.parse(localStorage.getItem('vuex'));
if (token) {
console.log('token', token.user.api_token);
//请求头添加token
config.headers.token = token.user.api_token;
}
// 在发送请求之前做些什么
//显示loading
document.getElementById('loading').style.display = 'block';
// config.baseURL = 'http://cp.';
// let baseUrl = process.env.NODE_ENV == 'development'?'':'http://cp'
return config;
}, function (error) {
// 对请求错误做些什么
//隐藏loading
document.getElementById('loading').style.display = 'none';
alert('网络异常,请重试!')
return Promise.reject(error);
});
axios.interceptors.response.use(function (response) {
// 对响应数据做点什么
//隐藏loading
document.getElementById('loading').style.display = 'none';
console.log('response:', response)
if (response.data.code != 0) {
alert(response.data.msg)
}
return response;
});
Vue.use(Vuex)
export default new Vuex.Store({
plugins: [createPersistedState()],//使用持久化的vuex
state:{},
...
vuex使用axios拦截器及持久化
最新推荐文章于 2024-05-24 18:11:10 发布