C++ 全栈知识体系C++ 全栈知识体系
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
✿导航
  • 基础
  • 函数
  • 知识点
  • IO框架
  • 新版本特性
  • 数据库原理
  • SQL语言
  • SQL - MySQL
  • NoSQL - Redis
  • NoSQL - ElasticSearch
  • 算法基础
  • 常见算法
  • 领域算法
  • 分布式算法
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • 计算机组成
  • 开发
  • 测试
  • 架构基础
  • 分布式系统
  • 微服务
  • 中间件
  • 概念
  • 理论
  • 架构设计原则
  • 设计模式
  • 协议
  • 技术选型
  • 编码规范
  • 流水线构建 - CI/CD
  • 知识点 - Linux
  • 网站 - Nginx
  • 容器化 - Docker
  • 容器编排 - Kubernetes
  • 服务网格 - Service Mesh Istio
  • 常用快捷键 - Shortcut
  • 工具使用 - Tools
  • 开源项目
  • 学习项目
  • 个人项目
  • 项目开发
  • 项目Idea
  • 并发
  • 部署
  • 分布式
  • 知识
  • 问题
  • 编程语言与技术
  • 系统与架构
  • 软件开发实践
  • 数据处理与应用设计
  • 个人
  • 产品
  • 团队
  • 知识体系
  • Vue
关于
  • 知识体系

    • 知识体系 - 入门
    • 知识体系 - CSS
    • 知识体系 - JavaScript
    • 知识体系 - 工程化
    • 知识体系 - 优化
    • 知识体系 - 测试
    • 知识体系 - 构建部署
    • 知识体系 - 资源
  • Vue2

    • Vue基础

      • Vue基础 - 简介
      • Vue基础 - 入门
      • Vue基础 - 模板语法
      • Vue基础 - 数据绑定
      • Vue基础 - MVVM模型
      • Vue基础 - 事件处理
      • Vue基础 - 计算属性
      • Vue基础 - 监视属性
      • Vue基础 - 绑定样式
      • Vue基础 - 条件渲染
      • Vue基础 - 列表渲染
      • Vue基础 - 过滤器
      • Vue基础 - 内置指令
      • Vue基础 - 自定义指令
      • Vue基础 - 生命周期
    • Vue组件

      • Vue组件 - 基础
      • Vue组件 - 非单文件组件
      • Vue组件 - 单文件组件
    • Vue脚手架

      • Vue脚手架 - 基础使用
      • Vue脚手架 - ref和props
      • Vue脚手架 - 混入
      • Vue脚手架 - 插件
      • Vue脚手架 - todoList案例
      • Vue脚手架 - 自定义事件
      • Vue脚手架 - 全局事件总线
      • Vue脚手架 - 消息订阅与发布(pubsub)
      • Vue脚手架 - Vue封装的过渡和动画
    • Vue中的Ajax

      • Vue中的Ajax - 基础
      • Vue中的Ajax - slot插槽
      • Vue中的Ajax - github案例学习
    • Vuex

      • Vuex - 基础
      • Vuex - 使用
    • Vue Router

      • Vue Router - 基础
      • Vue Router - 使用
      • Vue Router - 多级路由(嵌套路由)
      • Vue Router - 路由传参
      • Vue Router - 编程式路由导航
      • Vue Router - 缓存组件
      • Vue Router - 生命周期钩子
      • Vue Router - 导航守卫
      • Vue Router - 工作模式
  • Vue3

    • Vue3 - 快速上手
    • Vue3 - 创建Vue3.0工程
    • Vue3 - 常用 Composition API
    • Vue3 - 响应式原理对比
    • Vue3 - 生命周期对比
    • Vue3 - 其它 Composition API
    • Vue3 - 新的组件
    • Vue3 - 导航守卫
    • Vue3 - 其他

Vue Router - 导航守卫

内容

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

  2. 分类

    • 全局守卫
      • 前置守卫
      • 解析守卫
      • 后置守卫
    • 独享守卫
    • 组件内守卫
  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() //放行
      	}
      })
      
      //在 2.5.0+ 你可以用 router.beforeResolve 注册一个全局守卫。这和 router.beforeEach 类似,区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。
      
      //全局后置守卫:初始化时执行、每次路由切换后执行
      router.afterEach((to,from)=>{
      	console.log('afterEach',to,from)
      	if(to.meta.title){ 
      		document.title = to.meta.title //修改网页的title
      	}else{
      		document.title = 'vue_test'
      	}
      })
      

      路由里配置meta元数据:

    const router = new VueRouter({ routes:[ { name:'guanyu', path:'/about', component:About, meta:{title:'关于'} },

    
    * 独享守卫
    
    可以在路由配置上直接定义 beforeEnter 守卫:
    
    ```js
    const router =  new VueRouter({
       routes:[
       	{
       		name:'zhuye',
       		path:'/home',
       		component:Home,
       		meta:{title:'主页'},
       		children:[
       			{
       				name:'xinwen',
       				path:'news',
       				component:News,
       				meta:{isAuth:true,title:'新闻'},
       				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()
       					}
       			}
       		]
       	}
    
    • 组件内守卫
    详情
    <script>
       export default {
       	name:'About',
       	...
       	//通过路由规则,进入该组件时被调用
       	beforeRouteEnter (to, from, next) {
       		console.log('About--beforeRouteEnter',to,from)
       		if(to.meta.isAuth){ //判断是否需要鉴权
       			if(localStorage.getItem('school')==='atguigu'){
       				next()
       			}else{
       				alert('学校名不对,无权限查看!')
       			}
       		}else{
       			next()
       		}
       	},
    
       	//通过路由规则,离开该组件时被调用
       	beforeRouteLeave (to, from, next) {
       		console.log('About--beforeRouteLeave',to,from)
       		next()
       	}
       }
    </script>
    

完整的导航解析流程

  • 导航被触发。
  • 在失活的组件里调用 beforeRouteLeave 守卫。
  • 调用全局的 beforeEach 守卫。
  • 在重用的组件里调用 beforeRouteUpdate 守卫 (2.2+)。
  • 在路由配置里调用 beforeEnter。
  • 解析异步路由组件。
  • 在被激活的组件里调用 beforeRouteEnter。
  • 调用全局的 beforeResolve 守卫 (2.5+)。
  • 导航被确认。
  • 调用全局的 afterEach 钩子。
  • 触发 DOM 更新。
  • 调用 beforeRouteEnter 守卫中传给 next 的回调函数,创建好的组件实例会作为回调函数的参数传入。
Last Updated:
Contributors: klc407073648
Prev
Vue Router - 生命周期钩子
Next
Vue Router - 工作模式