当前位置: 首页 > news >正文

导航守卫有哪三种?

导航守卫主要分为三种:

  1. 全局前置守卫:使用 router.beforeEach 注册,作用是在路由切换开始前进行拦截和处理,可以用来进行一些全局的权限校验、登录状态检查等操作。

  2. 全局解析守卫:使用 beforeResolve 注册,作用是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,进行一些操作。

  3. 全局后置钩子:使用 afterEach 注册,作用是在导航成功完成后进行一些全局的清理操作,比如页面的埋点统计、日志记录等。

这些导航守卫适用于需要在路由切换过程中做一些额外处理的情况,比如权限控制、页面加载前后的操作等。

以下是一个简单的示例代码:

const router = new VueRouter({routes: [{path: '/admin',component: Admin,beforeEnter: (to, from, next) => {// 在进入 /admin 路由前进行权限校验if (user.isAdmin) {next(); // 确认跳转} else {next('/login'); // 重定向到登录页面}}}]
});router.beforeEach((to, from, next) => {// 在每次路由切换前进行全局的拦截处理,比如检查登录状态if (to.meta.requiresAuth && !user.isAuthenticated) {next('/login');} else {next();}
});router.afterEach((to, from) => {// 在每次路由切换后进行全局的清理操作,比如页面埋点统计trackPageView(to.path);
});

以上示例展示了如何使用全局前置守卫、全局解析守卫和全局后置钩子对路由进行拦截、处理和清理操作。这些导航守卫能够帮助我们在路由切换时进行额外的控制和操作。

相关文章:

  • jenkins+centos7上传发布net6+gitlab
  • C++单调向量算法:132 模式解法三枚举1
  • 【每日一题】—— C. Yarik and Array(Codeforces Round 909 (Div. 3))(贪心)
  • 【具身智能评估1】具身视觉语言规划(EVLP)仿真环境汇总
  • Vulkan渲染引擎开发教程 一、开发环境搭建
  • python基础练习题库实验3
  • Canal+Kafka实现MySQL与Redis数据同步(一)
  • 贪吃蛇小游戏
  • typora使用PicGo自动上传图片到chevereto图床
  • Docker简介
  • 选硬币该用动态规划
  • 【漏洞复现】泛微e-Weaver SQL注入
  • ubuntu中/etc/rc.local和/etc/init.d/rc.local的区别是什么
  • zookeperkafka学习
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • php的引用
  • 实现windows 窗体的自己画,网上摘抄的,学习了
  • 【每日笔记】【Go学习笔记】2019-01-10 codis proxy处理流程
  • 230. Kth Smallest Element in a BST
  • Akka系列(七):Actor持久化之Akka persistence
  • css的样式优先级
  • JavaScript-Array类型
  • JDK9: 集成 Jshell 和 Maven 项目.
  • JS数组方法汇总
  • Markdown 语法简单说明
  • Redis提升并发能力 | 从0开始构建SpringCloud微服务(2)
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • Yii源码解读-服务定位器(Service Locator)
  • 后端_ThinkPHP5
  • 基于MaxCompute打造轻盈的人人车移动端数据平台
  • 技术胖1-4季视频复习— (看视频笔记)
  • 聊一聊前端的监控
  • 前端学习笔记之观察者模式
  • 收藏好这篇,别再只说“数据劫持”了
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 我有几个粽子,和一个故事
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • [Shell 脚本] 备份网站文件至OSS服务(纯shell脚本无sdk) ...
  • Prometheus VS InfluxDB
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • # 手柄编程_北通阿修罗3动手评:一款兼具功能、操控性的电竞手柄
  • #Linux(帮助手册)
  • #前后端分离# 头条发布系统
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (11)MSP430F5529 定时器B
  • (6)添加vue-cookie
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (接口自动化)Python3操作MySQL数据库
  • (力扣)1314.矩阵区域和
  • .htaccess配置常用技巧
  • .NET 5.0正式发布,有什么功能特性(翻译)
  • .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
  • .Net IOC框架入门之一 Unity
  • .NET MVC第五章、模型绑定获取表单数据