阿珊详解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。
-
beforeEach:在导航守卫中调用,进入路由之前调用。可以通过next函数继续导航,或者通过返回false取消导航。 -
beforeEnter:在导航守卫中调用,进入路由之前调用。这个钩子可以访问to和from对象,可以通过next函数继续导航,或者通过返回false取消导航。 -
afterEach:在导航守卫中调用,进入路由之后调用。这个钩子可以访问to和from对象,但是不能取消导航。
以下是一个简单的示例:
// 导入 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 提供的在组件内部拦截器,可以在路由导航过程中对请求进行拦截处理。组件内的守卫有三种类型:beforeRouteEnter、beforeRouteUpdate 和 beforeRouteLeave。
-
beforeRouteEnter:在导航守卫中调用,进入路由之前调用。此时,组件实例还没有被创建。可以通过next函数继续导航,或者通过返回false取消导航。 -
beforeRouteUpdate:在导航守卫中调用,路由更新之前调用。此时,组件实例已经被创建,可以通过next函数继续导航,或者通过返回false取消导航。 -
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应用更加安全和高效。🚀
参考资料:
- Vue Router官方文档
- Vue.js官方文档:路由
🌟 感谢您的阅读!如果您有任何疑问或建议,欢迎在评论区留言。💬
相关文章:
阿珊详解Vue Router的守卫机制
🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…...
python淘宝网页爬虫数据保存到 csv和mysql(selenium)
数据库连接设置(表和字段要提前在数据库中建好) # 数据库中要插入的表 MYSQL_TABLE goods# MySQL 数据库连接配置,根据自己的本地数据库修改 db_config {host: localhost,port: 3306,user: root,password: ma*****6,database: may2024,charset: utf8mb…...
云计算中仲裁节点和仲裁可用区介绍
在云计算中,仲裁是指当多个节点或实例之间发生争议或冲突时,由一个独立的第三方机构或节点来解决争议或冲突的过程。仲裁通常用于解决云计算中的资源分配、数据一致性、服务质量等问题。 仲裁的作用主要有以下几点: 1. 保证资源分配的公平性…...
Python的requests库发送HTTPS请求时,SSL证书验证的流程
建立连接:当你使用requests库发送HTTPS请求时,它会尝试与目标服务器建立安全的SSL连接。 获取服务器SSL证书:服务器会将自己的SSL证书发送给客户端(即你的请求)。 验证证书:requests库会验证服务器返回的…...
基于 HBase Phoenix 构建实时数仓(3)—— Phoenix 安装
目录 一、主机规划 二、Phoenix 安装 1. 解压、配置环境 2. 将 phoenix-server-hbase-2.5-5.1.3.jar 文件复制到 HBase 的 lib 目录中 3. 重启 HBase 集群 4. 安装验证 (1)连接 HBase (2)视图映射 (3…...
Python IDE
Python IDE 本文为大家推荐几款款不错的 Python IDE(集成开发环境),比较推荐 PyCharm,当然你可以根据自己的喜好来选择适合自己的 Python IDE。 PyCharm PyCharm 是由 JetBrains 打造的一款 Python IDE。 PyCharm 具备一般 Pyt…...
Vue3和Vue2的区别
Vue 3 是 Vue.js 的下一个主要版本,它引入了许多新特性和优化,与 Vue 2 相比有一些显著的区别。以下是一些主要的区别: 性能提升: Vue 3 提供了更快的虚拟 DOM,减少了渲染和更新时间。使用 Proxy 重写了响应式系统,使…...
【内推】新风口-大模型独角兽公司minimax
先上内推链接: MiniMax社招内推码: AK3XEJ6 投递链接: https://vrfi1sk8a0.jobs.feishu.cn/s/iFY5WFgE 岗位:前端、后端、算法,基础架构都有,大量hc 公司介绍: 国内同时拥有文本、语音、视觉三种基础大模型能力的创业…...
基于单片机的水平角度仪系统设计
目 录 摘 要 I Abstract II 引 言 1 1控制系统设计 3 1.1系统方案设计 3 1.2系统工作原理 4 2硬件设计 6 2.1单片机 6 2.1.1单片机最小系统 6 2.1.2 STC89C52单片机的性能 7 2.2角度采集电路 8 2.2.1 ADXL345传感器的工作原理 9 2.2.2 ADXL345传感器倾角测量的原理 9 2.2.3 AD…...
Haproxy 负载均衡集群
一. Haproxy 1. Haproxy 介绍 HAProxy 是法国开发者威利塔罗 (Willy Tarreau) 在2000年使用C语言开发的一个开源软件,是一款具备高并发(一万以上)、高性能的TCP和HTTP负载均衡器,支持基于cookie的持久性,自动故障切换,支持正则…...
微服务知识03
1、ES搜索引擎,高性能的分布式搜索引擎,底层基于Lucene 主要用于应用程序中的搜索系统 日志收集 2、基础概念 3、ES处理流程 5、下载中文分词器 Releases infinilabs/analysis-ik GitHub 6、分词模式 最细粒度拆分、智能分词 7、Elaticsearch配置流程 (1)把文件拖进…...
JPEG照片被误删除如何恢复?学会这个方法就够了
JPG/JPEG是一种后缀名为“.jpg”或“.jpeg”的图形格式。它是存储照片图像的常用格式,因此我们可以使用数码相机、手机或其他设备来获取大量的JPG/JPEG文件。有时,我们会遇到由于意外删除、格式化驱动器或其他未知原因导致 JPEG 文件丢失的情况。无论哪种…...
红黑树的学习
红黑树 红黑树出自一种平衡的二叉查找树,是计算机科学中中用到的一种数据结构 1972年出现,当时被称之为平衡二叉B树。后来,1978年被修改为如今的红黑树 他是一种特殊的二叉查找树,红黑树的每一个节点上都有存储表示节点的颜色 …...
C# OpenCvSharp DNN FreeYOLO 人脸检测
目录 效果 模型信息 项目 代码 下载 C# OpenCvSharp DNN FreeYOLO 人脸检测 效果 模型信息 Inputs ------------------------- name:input tensor:Float[1, 3, 192, 320] --------------------------------------------------------------- Outp…...
单例九品--第五品
单例九品--第五品 上一品引入写在前边代码部分1代码部分2实现方式评注与思考下一品的设计思考 上一品引入 第四品中可能会因为翻译单元的链接先后顺序,造成静态初始化灾难的问题。造成的原因是因为存在调用单例对象前没有完成定义的问题,这一品将着重解…...
Lwip之TCP服务端示例记录(1对多)
前言 实现多个客户端同时连接初步代码结构已经实现完成(通过轮训的方式) // // Created by shchl on 2024/3/8. // #if 1#include <string.h> #include "lwip/api.h" #include "FreeRTOS.h" #include "task.h" #include "usart.h&…...
哲理:为什么你要学习编程这项技能
有一家饭店的大厨,烧得一手好菜,经过口碑相传,客人从五湖四海闻名而来。然而这对饭店的老板来说,并不单纯是一个好消息。因为客人不是奔着饭店,而是奔着大厨的手艺来的。老板必须想办法留住这位大厨,否则他…...
【机器学习300问】30、准确率的局限性在哪里?
一、什么是准确率? 在解答这个问题之前,我们首先得先回顾一下准确率的定义,准确率是机器学习分类问题中一个很直观的指标,它告诉我们模型正确预测的比例,即 还是用我最喜欢的方式,举例子来解释一下…...
融资项目——网关微服务
1. 网关的路由转发功能 在前后端分离的项目中,网关服务可以将前端的相关请求转发到相应的后端微服务中。 2. 网关微服务的配置 首先需要创建一个网关微服务,并添加依赖。 <!-- 网关 --><dependency><groupId>org.springframework.cl…...
飞驰云联CEO朱旭光荣获“科技领军人才”称号
2024年2月29日,苏州工业园区“优化营商环境暨作风效能建设大会”成功举办,会上公布了2023年度苏州工业园区第十七届第一批金鸡湖科技领军人才名单,Ftrans飞驰云联创始人兼CEO朱旭光先生凭借在数据安全以及文件交换领域取得的突出成果…...
Chapter03-Authentication vulnerabilities
文章目录 1. 身份验证简介1.1 What is authentication1.2 difference between authentication and authorization1.3 身份验证机制失效的原因1.4 身份验证机制失效的影响 2. 基于登录功能的漏洞2.1 密码爆破2.2 用户名枚举2.3 有缺陷的暴力破解防护2.3.1 如果用户登录尝试失败次…...
React Native 导航系统实战(React Navigation)
导航系统实战(React Navigation) React Navigation 是 React Native 应用中最常用的导航库之一,它提供了多种导航模式,如堆栈导航(Stack Navigator)、标签导航(Tab Navigator)和抽屉…...
【算法训练营Day07】字符串part1
文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接:344. 反转字符串 双指针法,两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...
html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码
目录 一、👨🎓网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站效果 五、🪓 代码实现 🧱HTML 六、🥇 如何让学习不再盲目 七、🎁更多干货 一、👨…...
安宝特案例丨Vuzix AR智能眼镜集成专业软件,助力卢森堡医院药房转型,赢得辉瑞创新奖
在Vuzix M400 AR智能眼镜的助力下,卢森堡罗伯特舒曼医院(the Robert Schuman Hospitals, HRS)凭借在无菌制剂生产流程中引入增强现实技术(AR)创新项目,荣获了2024年6月7日由卢森堡医院药剂师协会࿰…...
基于IDIG-GAN的小样本电机轴承故障诊断
目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) 梯度归一化(Gradient Normalization) (2) 判别器梯度间隙正则化(Discriminator Gradient Gap Regularization) (3) 自注意力机制(Self-Attention) 3. 完整损失函数 二…...
STM32---外部32.768K晶振(LSE)无法起振问题
晶振是否起振主要就检查两个1、晶振与MCU是否兼容;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容(CL)与匹配电容(CL1、CL2)的关系 2. 如何选择 CL1 和 CL…...
c++第七天 继承与派生2
这一篇文章主要内容是 派生类构造函数与析构函数 在派生类中重写基类成员 以及多继承 第一部分:派生类构造函数与析构函数 当创建一个派生类对象时,基类成员是如何初始化的? 1.当派生类对象创建的时候,基类成员的初始化顺序 …...
AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...
土建施工员考试:建筑施工技术重点知识有哪些?
《管理实务》是土建施工员考试中侧重实操应用与管理能力的科目,核心考查施工组织、质量安全、进度成本等现场管理要点。以下是结合考试大纲与高频考点整理的重点内容,附学习方向和应试技巧: 一、施工组织与进度管理 核心目标: 规…...
