title: 使用 addRouteMiddleware 动态添加中间

date: 2024/8/4

updated: 2024/8/4

author: cmdragon

excerpt:

摘要:文章介绍了Nuxt3中addRouteMiddleware的使用方法,该功能允许开发者动态添加路由中间件,以实现诸如权限检查、动态重定向及路由变化时的特定操作。内容涵盖路由中间件的概念、addRouteMiddleware的语法、参数、使用示例(包括匿名中间件、命名中间件、全局中间件、覆盖现有中间件)及调试技巧。强调了此功能为Nuxt3应用带来的灵活性和便利性。

categories:

  • 前端开发

tags:

  • Nuxt3
  • 中间件
  • 路由
  • 动态
  • 权限
  • 重定向
  • 导航



扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

在 Nuxt3 中,addRouteMiddleware 允许开发者在应用程序中动态添加路由中间件。这为你提供了灵活性,可以在不同情况下执行导航守卫,例如处理权限、重定向,以及在路由变化时执行特定操作。

什么是路由中间件?

路由中间件是一个函数,可以在用户导航到特定路由前执行某些操作。它通常用于:

  • 检查用户权限
  • 动态重定向用户
  • 登录或加载数据

在 Nuxt3 中,所有中间件通常位于 middleware/ 目录中,但通过使用 addRouteMiddleware,你可以在运行时动态添加它们。

addRouteMiddleware 语法与参数

语法

addRouteMiddleware(name: string | RouteMiddleware, middleware?: RouteMiddleware, options: AddRouteMiddlewareOptions = {})

参数

  • name: (string | RouteMiddleware)

    • 可以是字符串(用于命名中间件)或一个路由中间件函数,类型为 RouteMiddleware
  • middleware: (RouteMiddleware)

    • 这是一个函数,接受两个参数:

      • to: 目标路由对象,包含用户要访问的路由信息。
      • from: 源路由对象,包含用户当前所在的路由信息。
  • options: (AddRouteMiddlewareOptions)

    • 一个可选的对象,用来设置中间件的额外选项。当前可以设置的选项是:

      • global: (boolean) 如果设置为 true,则该中间件为全局中间件,默认为 false

使用 addRouteMiddleware

1. 匿名路由中间件

在你需要简单的逻辑处理时,创建匿名路由中间件非常方便。

示例:禁止访问特定页面

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
addRouteMiddleware((to, from) => {
// 如果用户尝试访问 /forbidden 路径,则阻止导航
if (to.path === '/forbidden') {
console.log('访问被阻止:用户尝试访问从未授权的路径:', to.path);
return false; // 阻止导航
}
});
});

解释:

在上述示例中,如果用户尝试访问 /forbidden 页面,导航将被阻止并输出日志。

2. 命名路由中间件

命名路由中间件可以用字符串命名,便于后续调用和覆盖。

示例:记录每次导航日志

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
addRouteMiddleware('logger-middleware', (to, from) => {
console.log('用户从', from.path, '导航到', to.path);
});
});

解释:

在这个示例中,我们为中间件命名为 logger-middleware。这个中间件将在每次导航时输出用户的导航日志。可以通过 addRouteMiddleware 的方式再次覆盖同名中间件。

3. 全局路由中间件

全局中间件在每次路由变更时都会执行,适用于需要在每个路由之间共享逻辑的场景。

示例:全局访问控制检查

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
addRouteMiddleware('auth-check', (to, from) => {
const isAuthorized = false; // 假设这里是你的认证逻辑 if (!isAuthorized) {
console.warn('用户未授权,重定向到登录页面');
return navigateTo('/login'); // 重定向到登录页面
}
}, { global: true });
});

解释:

在这个示例中,我们创建了一个全局中间件 auth-check,每次路由更改时都会检查用户是否被授权。如果用户未授权,则重定向到 /login 页面。

4. 覆盖现有中间件

当使用命名的中间件时,新的中间件将覆盖已有的同名中间件。如下所示:

// middleware/auth.js
export default defineNuxtRouteMiddleware((to, from) => {
// 原有逻辑
}); // 然后在 plugins 中添加覆盖
// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
addRouteMiddleware('auth', (to, from) => {
console.log('覆盖了旧的 auth 中间件');
// 新的逻辑
});
});

在这个例子中,plugins/my-plugin.ts 中的中间件将覆盖 middleware/auth.js 中的内容。这样的特性可以帮助我们在特定条件下修改原有逻辑。

进行中间件调试

在开发过程中,调试中间件是个重要步骤。可以使用简单的 console.log 输出调试信息,帮助理解中间件的执行流程。例如:

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
addRouteMiddleware((to, from) => {
console.log('[Middleware Debug]', 'From:', from.path, 'To:', to.path);
});
});

这可以帮助你确认中间件的执行顺序和路径变更。

总结

通过使用 addRouteMiddleware,你可以灵活地在 Nuxt3 应用中添加、覆盖和管理路由中间件。这为实现复杂的导航逻辑、访问控制和数据处理提供了必要工具。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:使用 addRouteMiddleware 动态添加中间 | cmdragon's Blog

往期文章归档:

使用 addRouteMiddleware 动态添加中间的更多相关文章

  1. js动态添加事件-事件委托

    作者:白狼 出处:http://www.manks.top/javascript-dynamic-event.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给 ...

  2. 后台动态添加的button,如何触发button_click事件?

    后台动态添加的button,需要在Page_Load或者Page_Init重新动态生成才能执行button_click public Panel GetContrlType() { Panel pan ...

  3. jquery动态添加的html,第三方插件无法生效的情况

    今天一个问题纠结了半天,问题如下图  问题大致就是如上,新增的内容死活点不起,插件没有生效,在一个装逼前端群里面问,给我的答案是叫我去了解事件委托,了解一下事件冒泡!! 好吧,我一上午加半个下午的时间 ...

  4. 【Java EE 学习 75 下】【数据采集系统第七天】【二进制运算实现权限管理】【使用反射初始化权限表】【权限捕获拦截器动态添加权限】

    一.使用反射动态添加权限 在该系统中,我使用struts2的时候非常规范,访问的Action的形式都是"ActionClassName_MethodName.action?参数列表" ...

  5. Hadoop学习笔记—13.分布式集群中节点的动态添加与下架

    开篇:在本笔记系列的第一篇中,我们介绍了如何搭建伪分布与分布模式的Hadoop集群.现在,我们来了解一下在一个Hadoop分布式集群中,如何动态(不关机且正在运行的情况下)地添加一个Hadoop节点与 ...

  6. Net作业调度(五)—quartz.net动态添加job设计

    介绍 在实际项目使用中quartz.net中,都希望有一个管理界面可以动态添加job,而避免每次都要上线发布. 也看到有园子的同学问过.这里就介绍下实现动态添加job的几种方式, 也是二次开发的核心模 ...

  7. vue中v-bind:class动态添加class

    1.html代码 <template v-for='item in names'> <div id="app" class="selectItem&qu ...

  8. js表单动态添加数据并提交

    情景1:已经存在form对象了,动态为form增加对象并提交 function formAppendSubmit(){ var myform=$('#newArticleForm'); //得到for ...

  9. [转]jquery append 动态添加的元素事件on 不起作用的解决方案

    用jquery添加新元素很容易,面对jquery append 动态添加的元素事件on 不起作用我们该如何解决呢?on方法中要先找到原选择器(如例.info),再找到动态添加的选择器(如列.delet ...

  10. jQuery给动态添加的元素绑定事件的方法

    我们在开发过程会遇到无法给动态元素添加绑定事件,解决方案如下: 例如 <div id="testdiv">   <ul></ul> </d ...

随机推荐

  1. 荣耀无5G开关,荣耀手机,荣耀80GT

    荣耀无5G开关,荣耀手机,荣耀80GT. Magic OS 版本号是:7.0.0.138(C00E135R2P6). 解决方法: 1.进入设置-关于手机-连续点击7次版本号. 会提示,开发者选项已开启 ...

  2. C#.NET 微信上传电子小票

    HttpWebRequest 时,不认图片的Content-Type.Content-Type 实际是有传的. 报错内容:{"code":"PARAM_ERROR&quo ...

  3. 判断URL是否编码,编码后的sign对签名和验签都有影响,导致验签不通过

    判断URL是否编码,编码后的sign对签名和验签都有影响,导致验签不通过如果含有 + %符号无法判断, 否则判断不准或报错 Exception in thread "main" j ...

  4. C++类与对象详解

    什么是类和对象 类和对象的概念 类是对象的抽象,对象是对客观事物的抽象. 用通俗的话来说: 类是类别的意思,是数据类型. 对象是类别下的具体事物. 也就是说: 类是数据类型,对象是变量. 比如: 水果 ...

  5. CAP 8.2 版本发布通告

    前言 今天我们很高兴宣布 CAP 发布 8.2 版本正式版,我们在这个版本中主要致力于对订阅着并行执行的特性提供支持,同时添加了对在订阅者中对消息头的控制行为. 下面,具体看一下我们新版本的功能吧. ...

  6. git clone 时拉取子模块

    git clone 时拉取子模块 对还未下载的项目: git clone --recursive 对已下载的项目: git submodule sync git submodule update -- ...

  7. Python中使用MySQL模糊查询的方法

    1.方法一:使用pymysql库的方法 当在Python中使用MySQL进行模糊查询时,我们通常会使用pymysql或mysql-connector-python这样的库来连接MySQL数据库并执行查 ...

  8. 【ClickHouse】3:clickhouse基本操作一 用户权限管理

    背景介绍: 有三台CentOS7服务器安装了ClickHouse HostName IP 安装程序 程序端口 centf8118.sharding1.db 192.168.81.18 clickhou ...

  9. CF1591F 题解

    先不管值域,设计状态 \(dp_{i,j}\) 表示考虑前 \(i\) 个数最后一个数为 \(j\) 的方案数,那么有如下转移: \[dp_{i,j} = dp_{i-1,k} (j \not = k ...

  10. Java 自定义注解校验字段唯一性

    业务场景 在项目中,某些情景下我们需要验证编码是否重复,账号是否重复,身份证号是否重复等... 那么有没有办法可以解决这类似的重复代码量呢? 我们可以通过自定义注解校验的方式去实现,在实体类上面加上自 ...