Vue+axios 实现http拦截及路由拦截

 现现在,每一个前端对于Vue都不会陌生,Vue框架是现在最流行的前端框架之一,其势头直追react.最近我用vue作了一个项目,下面即是我从中取得的一点收获.前端

 基于如今用vue+webpack搭建项目的文档已经有不少了,我就再也不累述了.vue

  技术栈react

  • vue2.0
  • vue-router
  • axios

  拦截器webpack

    首先咱们要明白设置拦截器的目的是什么,当咱们须要统一处理http请求和响应时咱们经过设置拦截器处理方便不少.
ios

    这个项目我引入了element ui框架,因此我是结合element中loading和message组件来处理的.咱们能够单独创建一个http的js文件处理axios,再到main.js中引入.web

    

 1 /**
 2  * http配置
 3  */
 4 // 引入axios以及element ui中的loading和message组件
 5 import axios from 'axios'
 6 import { Loading, Message } from 'element-ui'
 7 // 超时时间
 8 axios.defaults.timeout = 5000
 9 // http请求拦截器
10 var loadinginstace
11 axios.interceptors.request.use(config => {
12   // element ui Loading方法
13   loadinginstace = Loading.service({ fullscreen: true })
14   return config
15 }, error => {
16   loadinginstace.close()
17   Message.error({
18     message: '加载超时'
19   })
20   return Promise.reject(error)
21 })
22 // http响应拦截器
23 axios.interceptors.response.use(data => {// 响应成功关闭loading
24   loadinginstace.close()
25   return data
26 }, error => {
27   loadinginstace.close()
28   Message.error({
29     message: '加载失败'
30   })
31   return Promise.reject(error)
32 })
33 
34 export default axios

 

   这样咱们就统一处理了http请求和响应的拦截.固然咱们能够根据具体的业务要求更改拦截中的处理.vue-router

 路由拦截element-ui

    咱们能够经过路由拦截作什么?我认为最主要的即是对权限的控制,好比有的页面须要登陆了才能进入,有些页面不一样身份渲染不一样.接下来简单的讲一下登陆拦截.
axios

    

 1 import Vue from 'vue'
 2 import Router from 'vue-router'
 3 
 4 Vue.use(Router)
 5 
 6 const router = new Router({
 7   routes: [
 8     {
 9       path: '/',
10       /*
11       *  按需加载 
12       */
13       component: (resolve) => {
14         require(['../components/Home'], resolve)
15       }
16     }, {
17       path: '/record',
18       name: 'record',
19       component: (resolve) => {
20         require(['../components/Record'], resolve)
21       }
22     }, {
23       path: '/Register',
24       name: 'Register',
25       component: (resolve) => {
26         require(['../components/Register'], resolve)
27       }
28     }, {
29       path: '/Luck',
30       name: 'Luck', 
// 须要登陆才能进入的页面能够增长一个meta属性
31 meta: { 32 requireAuth: true 33 }, 34 component: (resolve) => { 35 require(['../components/luck28/Luck'], resolve) 36 } 37 } 38 ] 39 }) 40 // 判断是否须要登陆权限 以及是否登陆 41 router.beforeEach((to, from, next) => { 42 if (to.matched.some(res => res.meta.requireAuth)) {// 判断是否须要登陆权限 43 if (localStorage.getItem('username')) {// 判断是否登陆 44 next() 45 } else {// 没登陆则跳转到登陆界面 46 next({ 47 path: '/Register', 48 query: {redirect: to.fullPath} 49 }) 50 } 51 } else { 52 next() 53 } 54 }) 55 56 export default router

      这样就作好了登陆拦截.咱们只需在main.js中引入router就能够了.前端框架

      实现权限的控制咱们还能够经过Vuex来实现,可是若是是小型项目就不必引入Vuex了.

   以上是我作项目过程当中的一些收获,因为入Vue的坑也才两月不到,有些地方可能有不足之处,欢迎你们指正,我会悉心听取.

相关文章
相关标签/搜索