Vue学习之--------路由守卫(2022/9/6)

简介: 这篇文章详细介绍了Vue路由守卫的概念和应用,包括全局守卫、独享守卫和组件内守卫的实现方法,并通过实际代码示例和测试效果展示了如何对路由进行权限控制,以及Vue路由器的两种工作模式:hash模式和history模式。

1、路由(Router)的基本使用:1
2、Vue学习之--------多级路由的使用:2
3、路由的query、params参数、路由命名:3
4、编程式路由导航、缓存路由组件、新的钩子函数:4

1、路由守卫

1.1、作用

对路由进行权限控制

1.2、分类

全局守卫、独享守卫、组件内守卫

1.3、全局守卫

   //全局前置守卫:初始化时执行、每次路由切换前执行
   router.beforeEach((to,from,next)=>{
       console.log('beforeEach',to,from)
       if(to.meta.isAuth){ //判断当前路由是否需要进行权限控制
           if(localStorage.getItem('school') === 'atguigu'){ //权限控制的具体规则
               next() //放行
           }else{
               alert('暂无权限查看')
               // next({name:'guanyu'})
           }
       }else{
           next() //放行
       }
   })

   //全局后置守卫:初始化时执行、每次路由切换后执行
   router.afterEach((to,from)=>{
       console.log('afterEach',to,from)
       if(to.meta.title){ 
           document.title = to.meta.title //修改网页的title
       }else{
           document.title = 'vue_test'
       }
   })

1.3.1 全局守卫在实际中的运用

代码

在这里插入图片描述

在这里插入图片描述

测试效果

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

1.4. 独享守卫

   beforeEnter(to,from,next){
       console.log('beforeEnter',to,from)
       if(to.meta.isAuth){ //判断当前路由是否需要进行权限控制
           if(localStorage.getItem('school') === 'atguigu'){
               next()
           }else{
               alert('暂无权限查看')
               // next({name:'guanyu'})
           }
       }else{
           next()
       }
   }

1.4.1 独享守卫在实际中的应用

在这里插入图片描述

测试结果

在这里插入图片描述

1.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的问题。

默认是hash模式
在这里插入图片描述

开启history模式

history模式
在这里插入图片描述

测试效果
在这里插入图片描述

相关文章
|
3天前
|
JavaScript 前端开发
Vue项目使用px2rem
Vue项目使用px2rem
|
4天前
|
缓存 JavaScript
vue学习(12)计算属性
vue学习(12)计算属性
15 2
|
3天前
|
JavaScript
Vue组件传值异步问题--子组件拿到数据较慢
Vue组件传值异步问题--子组件拿到数据较慢
8 0
|
3天前
|
缓存 JavaScript
Vue中的keep-alive是什么意思?以及如何使用
Vue中的keep-alive是什么意思?以及如何使用
|
7天前
|
JavaScript
vue学习(3)模板语法
vue学习(3)模板语法
38 11
|
7天前
|
存储 JavaScript 前端开发
vue学习(2)
vue学习(2)
195 65
|
7天前
|
JavaScript 算法 前端开发
vue学习(1)
vue学习(1)
195 62
|
6天前
|
JavaScript
vue学习(4)数据绑定
vue学习(4)数据绑定
19 10
|
6天前
|
JavaScript 前端开发
vue学习(6)
vue学习(6)
23 9
|
6天前
|
JavaScript 开发者
vue学习(5)
vue学习(5)
21 7