首页 > 其他 > 详细

vue拦截

时间:2019-10-31 13:55:30      阅读:94      评论:0      收藏:0      [点我收藏+]
```javascript
import Vue from ‘vue‘
import App from ‘./App.vue‘
import router from ‘./router‘
import store from ‘./store‘
import ElementUI from ‘element-ui‘;
import ‘element-ui/lib/theme-chalk/index.css‘
Vue.use(ElementUI)
//清除默认样式
import axios from ‘axios‘

//因为Vue的底层原理也是往js原型上挂载方法,所以我们可以把axios挂载在全局
Vue.prototype.$http = axios;
// 全局配置baseURL
axios.defaults.baseURL = ‘http://www.litc.pro:9999/v1‘;
// 添加请求拦截器
axios.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  let token = localStorage.getItem(‘token‘)||‘‘
  config.headers.Authorization = token
  return config;
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error);
});

// 添加响应拦截器
axios.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  //console.log(response.data)
  response = response.data
  return response;
}, function (error) {
  // 对响应错误做点什么
  Vue.prototype.$message({
    showClonse:true,
    type:‘error‘,
    message:error.response.data.errMsg
  })
  return Promise.reject(error);
});
//导航守卫
router.beforeEach((to,from,next)=>{
let token = localStorage.getItem(‘token‘) || ‘‘
//拦截已登录的状态
//console.log(to.path)
//如果你没有token 并且去的不是signin页面
if(token && to.path === ‘/signIn‘){
  return next(‘/home‘)
}
if(token || to.path === ‘/signIn‘){
  next()
}else{
  //如果没有登录,就跳转回 /
  next(‘/‘)
}
})
Vue.config.productionTip = false


new Vue({
  router,
  store,
  render: h => h(App)
}).$mount(‘#app‘)
```

  

vue拦截

原文:https://www.cnblogs.com/tuziling/p/11770431.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!