阿珊详解Vue Router的守卫机制

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 摘要:
    • 引言:
    • 正文:
      • 1. 🔧 全局守卫
      • 2. 🔧 路由独享的守卫
      • 3. 🔧 组件内的守卫
    • 总结
    • 参考资料:

摘要:

🤔 Vue Router提供了强大的守卫机制,用于在路由跳转前后进行操作和判断。本文将介绍Vue Router的守卫类型及其应用,帮助读者更好地掌握路由管理。👩‍💻

引言:

🌈 Vue.js以其简洁的语法和声明式的数据绑定受到开发者的喜爱。在单页面应用(SPA)中,路由管理是不可或缺的功能。Vue Router作为Vue的路由器库,提供了丰富的功能,其中守卫机制是其中一个重要的特点。本文将带你深入了解Vue Router的守卫机制,并学会如何使用它们来管理路由。🚀

正文:

1. 🔧 全局守卫

类型:全局守卫是对路由跳转的全局控制,可以在路由跳转的前后进行操作。
应用场景:例如,全局判断用户是否登录,根据登录状态决定是否允许访问某个路由。

全局守卫是 Vue Router 提供的全局拦截器,可以在路由导航过程中对请求进行拦截处理。全局守卫有三种类型:beforeEach、beforeEnter 和 afterEach。

  1. beforeEach:在导航守卫中调用,进入路由之前调用。可以通过 next 函数继续导航,或者通过返回 false 取消导航。

  2. beforeEnter:在导航守卫中调用,进入路由之前调用。这个钩子可以访问 tofrom 对象,可以通过 next 函数继续导航,或者通过返回 false 取消导航。

  3. afterEach:在导航守卫中调用,进入路由之后调用。这个钩子可以访问 tofrom 对象,但是不能取消导航。

以下是一个简单的示例:

// 导入 Vue 和 Vue Router
import Vue from 'vue';
import VueRouter from 'vue-router';// 注册 Vue Router
Vue.use(VueRouter);// 定义路由
const routes = [{path: '/',name: 'Home',component: HomeComponent,},{path: '/about',name: 'About',component: AboutComponent,},
];// 创建 router 实例
const router = new VueRouter({mode: 'history',routes,
});// 在全局守卫中使用 beforeEach
router.beforeEach((to, from, next) => {console.log('全局守卫 - beforeEach');next();
});// 在全局守卫中使用 beforeEnter
router.beforeEnter((to, from, next) => {console.log('全局守卫 - beforeEnter');next();
});// 在全局守卫中使用 afterEach
router.afterEach((to, from) => {console.log('全局守卫 - afterEach');
});// 导出 router 实例
export default router;

在这个示例中,我们定义了全局守卫,分别在进入路由之前、进入路由之后和导航守卫中调用。当导航到不同的路由时,会打印相应的全局守卫日志。

2. 🔧 路由独享的守卫

类型:路由独享的守卫是指对单个路由进行控制,可以在进入或离开路由时进行操作。
应用场景:例如,进入某个路由前检查权限,或者离开某个路由前保存数据。

路由独享的守卫是 Vue Router 提供的在特定路由上拦截器,可以在路由导航过程中对请求进行拦截处理。路由独享的守卫通过在路由对象上定义 beforeEnter 属性来实现。

下面是一个简单的示例:

const routes = [{path: '/',name: 'Home',component: HomeComponent,beforeEnter: (to, from, next) => {// 在这里编写拦截逻辑if (/* 满足条件 */) {next(); // 继续导航} else {next('/login'); // 跳转到登录页面}},},{path: '/about',name: 'About',component: AboutComponent,},
];

在这个示例中,我们为 / 路由添加了 beforeEnter 属性,当导航到 / 路由时,会先执行 beforeEnter 中的逻辑,如果满足条件,则继续导航,否则跳转到登录页面。

需要注意的是,路由独享的守卫只对当前路由生效,不会影响其他路由的导航。

3. 🔧 组件内的守卫

类型:组件内的守卫是对组件路由的局部控制,可以在组件加载、更新或销毁时进行操作。
应用场景:例如,在组件加载时获取数据,或者在组件更新时进行数据更新。

组件内的守卫是 Vue Router 提供的在组件内部拦截器,可以在路由导航过程中对请求进行拦截处理。组件内的守卫有三种类型:beforeRouteEnterbeforeRouteUpdatebeforeRouteLeave

  1. beforeRouteEnter:在导航守卫中调用,进入路由之前调用。此时,组件实例还没有被创建。可以通过 next 函数继续导航,或者通过返回 false 取消导航。

  2. beforeRouteUpdate:在导航守卫中调用,路由更新之前调用。此时,组件实例已经被创建,可以通过 next 函数继续导航,或者通过返回 false 取消导航。

  3. beforeRouteLeave:在导航守卫中调用,离开路由之前调用。此时,组件实例已经被创建,可以通过 next 函数继续导航,或者通过返回 false 取消导航。

以下是一个简单的示例:

export default {name: 'App',beforeRouteEnter(to, from, next) {console.log('组件内守卫 - beforeRouteEnter');next();},beforeRouteUpdate(to, from, next) {console.log('组件内守卫 - beforeRouteUpdate');next();},beforeRouteLeave(to, from, next) {console.log('组件内守卫 - beforeRouteLeave');next();},
};

在这个示例中,我们定义了组件内的守卫,分别在进入路由之前、路由更新之前和离开路由之前调用。当导航到不同的路由时,会打印相应的组件内守卫日志。

需要注意的是,组件内的守卫只能拦截当前组件的导航,无法拦截其他组件的导航。

总结

Vue Router的守卫机制是其强大的功能之一,通过全局守卫、路由独享的守卫和组件内的守卫,我们可以在路由跳转的前后进行各种操作和判断,从而实现对路由的精细化管理。在实际开发中,根据项目需求合理使用守卫机制,可以使我们的Vue应用更加安全和高效。🚀

参考资料:

  1. Vue Router官方文档
  2. Vue.js官方文档:路由

🌟 感谢您的阅读!如果您有任何疑问或建议,欢迎在评论区留言。💬

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/272300.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用一个 Python 脚本实现依次运行其他多个带 argparse 命令行参数的 .py 文件

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 问题描述:在 Windows 环境中,您希望通过一个 Python 脚本来实现特定的自动化任务,该任务需要依次运行其他多个带 argparse 命令行参数的 .py 文件。您希望找到一种简…

CXYGZL实现钉钉、飞书和微信全面覆盖!!!

非常欣慰能在这里与大家分享,CXYGZL已圆满实现多端互通的目标!!! 无论您是在手机、电脑还是平板上使用钉钉、企微还是飞书,只需将CXYGZL轻松集成到您的办公软件中,即可实现无缝审批处理各项任务&#xff0c…

计算机找不到msvcr120.dll的五种修复方法,轻松搞定msvcr120.dll丢失问题

当计算机系统中msvcr120.dll文件丢失时,可能会引发一系列运行问题和故障现象。msvcr120.dll是Microsoft Visual C Redistributable Package的一部分,对于许多Windows应用程序的正常运行至关重要。由于msvcr120.dll是许多软件在运行过程中依赖的重要动态链…

Java项目:44 ssm003在线医疗服务系统+jsp(含文档)

作者主页:源码空间codegym 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 主要功能 前台登录: 注册用户:用户名、密码、姓名、联系电话 注册医生:医生工号、密码、医生姓名、职称、…

idea:springboot项目搭建

目录 一、创建项目 1、File → New → Project 2、Spring Initializr → Next 3、填写信息 → Next 4、web → Spring Web → Next 5、填写信息 → Finish 6、处理配置不合理内容 7、注意事项 7.1 有依赖包,却显示找不到依赖,刷新一下maven 7.…

基于 HBase Phoenix 构建实时数仓(2)—— HBase 完全分布式安装

目录 一、开启 HDFS 机柜感知 1. 增加 core-site.xml 配置项 2. 创建机柜感知脚本 3. 创建机柜配置信息文件 4. 分发相关文件到其它节点 5. 重启 HDFS 使机柜感知生效 二、主机规划 三、安装配置 HBase 完全分布式集群 1. 在所有节点上配置环境变量 2. 解压、配置环境…

瑞_Redis_短信登录(一)

文章目录 项目介绍1 短信登录1.1 项目准备1.1.1 导入SQL1.1.2 导入后端项目1.1.3 导入前端项目 🙊 前言:本文章为瑞_系列专栏之《Redis》的实战篇的短信登录章节的项目准备小节。由于博主是从B站黑马程序员的《Redis》学习其相关知识,所以本系…

2023年12月CCF-GESP编程能力等级认证Python编程七级真题解析

本文收录于专栏《Python等级认证CCF-GESP真题解析》,专栏总目录・点这里 一、单选题(每题 2 分,共 30 分) 第1题 假设变量 x 为 float 类型,如果下面代码输入为 100,输出最接近( )。 A.0 B.-5 C.-8 D.8 答案:B 第2题 对于下面动态规划方法实现的函数,以下选项中…

简单BFF架构设计

又到周五了有了一个小时的闲暇时间简单写点东西,介绍一个简单的BFF的架构。BFF:Backends For Frontends,其实现在是个比较常见的前端架构设计的方案,其最大的优势便在于前端可以高度自由的在Node层做一些server端才可以做的东西,比如SSR、登录…

Vue保姆级项目教程:十万字零基础开发信贷管理系统!

项目简介与搭建过程 项目简介 需求背景 信贷管理系统是一种用于银行、金融机构或其他借贷组织用于管理信贷流程的软件系统。它可以帮助机构管理贷款申请、贷款审批、合同管理等相关流程,提高信贷业务的效率和准确性。 需求描述 本需求文档旨在定义信贷管理系统的功能和特…

代码随想录训练营第四天|面试题02.07链表相交

题目: 面试题 02.07. 链表相交 已解答 简单 相关标签 相关企业 提示 给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 图示两个链表在节点 c1 开始相交: 题目…

设计模式(工厂模式)

设计模式(工厂模式) 一、工厂模式介绍 在工厂模式中,父类决定生成示例的方式,但不决定所要生成的具体的类,具体的处理部分交给子类负责。这样就可以将生成示例的框架和生成示例的类解耦。 二、示例程序 以下示例程…

ARM中汇编语言的学习(加法、乘法、除法、左移、右移、按位与等多种命令操作实例以及ARM的 N、Z、C、V 标志位的解释)

汇编概述 汇编需要学习的大致框架如下: 汇编中的符号 1.指令;能够北嘁肷梢惶?2bit机器码,并且能够被cpui识别和执行 2.伪指令:本身不是指令,编译器可以将其替换成若干条指令 3.伪操作:不会生成指令…

Kafka | SpringBoot集成Kafka

SpringBoot集成Kafka 一、前言二、项目1. pom2. application.properties4. 消息生产者-测试5. 消息消费者 三、启动测试四、有总结的不对的地方/或者问题 请指正, 我在努力中 一、前言 该文章中主要对SpringBoot 集成Kafka 主要是 application.properties 与 pom坐标就算集成完…

HTML5基础2

drag 可以把拖放事件拆分成4个步骤 设置元素为可拖放。为了使元素可拖动&#xff0c;把 draggable 属性设置为 true 。 <img draggable"true"> 拖动什么。ondragstart 和 setData() const dragestart (ev)>{ev.dataTransfer.setData(play,ev.target.id)} …

[云原生] k8s之存储卷

一、emptyDir存储卷 当Pod被分配给节点时&#xff0c;首先创建emptyDir卷&#xff0c;并且只要该Pod在该节点上运行&#xff0c;该卷就会存在。正如卷的名字所述&#xff0c;它最初是空的。Pod 中的容器可以读取和写入emptyDir卷中的相同文件&#xff0c;尽管该卷可以挂载到每…

如何不丢精度保存PPT中的图片,实测有效

1.在powerpoint软件中 文件-》选项 -》高级-》设置为不压缩&#xff0c;且默认输出为最高 2.导入对应图片后&#xff0c;右键导出图片&#xff0c;选择.emf文件 3.使用windows自带的画图工具打开.emf文件&#xff0c;ctrls另存为.png文件 此方法亲测可以生成清晰度很高的图片

python:布伊山德U检验(Buishand U test,BUT)突变点检测(以NDVI时间序列为例)

作者:CSDN @ _养乐多_ 本文将介绍布伊山德U检验(Buishand U test,BUT)突变点检测代码。以 NDVI 时间序列为例。输入数据可以是csv,一列NDVI值,一列时间。代码可以扩展到遥感时间序列突变检测(突变年份、突变幅度等)中。 结果如下图所示, 文章目录 一、准备数据二、…

【JavaEE进阶】 @Transactional详解

文章目录 &#x1f343;前言&#x1f332;rollbackFor&#xff08;异常回滚属性&#xff09;&#x1f384;事务隔离级别&#x1f6a9;MySQL事务隔离级别&#x1f6a9;Spring事务隔离级别 &#x1f38b;Spring事务传播机制&#x1f6a9;什么是事务传播机制&#x1f6a9;事务有哪…

spark 实验二 RDD编程初级实践

目录 一. pyspark交互式编程示例&#xff08;学生选课成绩统计&#xff09; 该系总共有多少学生&#xff1b; 该系DataBase课程共有多少人选修&#xff1b; 各门课程的平均分是多少&#xff1b; 使用累加器计算共有多少人选了DataBase这门课。 二.编写独立应用程序实现数…