vue路由守卫

  • Post author:
  • Post category:vue


1.路由守卫

1. 作用:对路由进行权限控制

2. 分类:全局守卫、独享守卫、组件内守卫

3. 全局守卫:

1.全局前置守卫:初始化时执行、每次路由切换前执行



   router.beforeEach((to,from,next)=>{

      console.log('beforeEach',to,from)

      if(to.meta.isAuth){ //判断当前路由是否需要进行权限控制

         if(localStorage.getItem('school') === 'name'){ //权限控制的具体规则

            next() //放行

         }else{

            alert('暂无权限查看')

            // next({name:'guanyu'})

         }

      }else{

         next() //放行

      }

   })

2.全局后置守卫:初始化时执行、每次路由切换后执行

   router.afterEach((to,from)=>{

      console.log('afterEach',to,from)

      if(to.meta.title){ 

         document.title = to.meta.title //修改网页的title

      }else{

         document.title = 'vue_test'

      }

   })

4. 独享守卫:

   beforeEnter(to,from,next){

      console.log('beforeEnter',to,from)

      if(to.meta.isAuth){ //判断当前路由是否需要进行权限控制

         if(localStorage.getItem('school') === 'name'){

            next()

         }else{

            alert('暂无权限查看')

            // next({name:'guanyu'})

         }

      }else{

         next()

      }

   }

5. 组件内守卫:

   //进入守卫:通过路由规则,进入该组件时被调用

   beforeRouteEnter (to, from, next) {

   },

   //离开守卫:通过路由规则,离开该组件时被调用

   beforeRouteLeave (to, from, next) {

   }

2.路由器的两种工作模式

1. 对于一个url来说,什么是hash值?—— #及其后面的内容就是hash值。

2. hash值不会包含在 HTTP 请求中,即:hash值不会带给服务器。

3. hash模式:

1. 地址中永远带着#号,不美观 。

2. 若以后将地址通过第三方手机app分享,若app校验严格,则地址会被标记为不合法。

3. 兼容性较好。

4. history模式:

1. 地址干净,美观 。

2. 兼容性和hash模式相比略差。

3. 应用部署上线时需要后端人员支持,解决刷新页面服务端404的问题。



版权声明:本文为qq_43450834原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。