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

超级英雄的导航之旅:动态路由和嵌套路由

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 介绍动态路由的概念和用法
    • 处理带参数的路由
    • 创建嵌套路由的结构和用法

介绍动态路由的概念和用法

动态路由是指根据不同的参数或路径生成的路由。它允许我们根据特定的值动态创建路由,而不是在路由配置时硬编码地写入所有可能的路由。

动态路由的概念和用法如下:

  1. 定义动态路由路径:在路由配置中,可以使用冒号(:)来定义动态片段,表示该部分路径可以根据特定的值动态生成。
const router = new VueRouter({routes: [{path: '/users/:id',component: UserDetail}]
});

在上述代码中,路径 /users/:id 中的 :id 是一个动态片段,表示该部分路径可以匹配任意的值。

  1. 访问动态路由参数:在路由组件中,可以通过 $route.params 来访问动态路由的参数。
// UserDetail.vue
export default {created() {const userId = this.$route.params.id;// 使用 userId 做相应的操作,例如获取用户信息}
};

在上述代码中,使用 this.$route.params.id 可以获取路由的动态参数 id,并在组件中使用。

  1. 监听动态路由的变化:如果动态路由的参数发生变化,可以监听 $route 对象的变化,并通过钩子函数或观察者来处理。

钩子函数方式监听:

// UserDetail.vue
export default {beforeRouteUpdate(to, from, next) {const userId = to.params.id;// 根据新的 userId 做相应的操作next();}
};

观察者方式监听:

// UserDetail.vue
export default {watch: {'$route' (to, from) {const userId = to.params.id;// 根据新的 userId 做相应的操作}}
};

通过钩子函数或观察者,可以在动态路由参数发生变化时进行相应的操作,例如重新加载数据或更新组件。

动态路由允许我们根据不同的参数或路径生成路由,使得应用更灵活和可扩展。它适用于需要根据不同资源或实体显示不同内容的情况,例如显示不同用户的详细信息或不同文章的内容。

处理带参数的路由

处理带参数的路由是 Vue Router 中常见的需求之一。你可以使用动态路由或查询参数来处理带参数的路由。下面我将分别介绍它们的概念和用法:

  1. 动态路由参数:
    动态路由参数是将参数直接嵌入到路由的路径中。例如,对于路径 /users/:id,其中的 :id 就是一个动态路由参数。可以通过动态路由参数来实现根据不同的参数值动态生成路由。

定义动态路由路径时,在路由配置中使用冒号(:)来定义动态片段:

const router = new VueRouter({routes: [{path: '/users/:id',component: UserDetail}]
});

访问动态路由参数时,在路由组件中使用 $route.params 来获取参数的值:

// UserDetail.vue
export default {mounted() {const userId = this.$route.params.id;// 使用 userId 做相应的操作,例如获取用户信息}
};
  1. 查询参数:
    查询参数是以键值对的形式出现在 URL 中的参数。它们通常用于筛选、排序或传递其他可选参数。

定义带查询参数的路由路径时,可以使用 query 字段来指定查询参数:

const router = new VueRouter({routes: [{path: '/search',component: SearchResults}]
});

在页面跳转时,可以通过 $router.push 方法传递查询参数:

this.$router.push({path: '/search',query: {keyword: 'Vue',page: 1}
});

在路由组件中,可以通过 $route.query 来获取查询参数的值:

// SearchResults.vue
export default {mounted() {const keyword = this.$route.query.keyword;const page = this.$route.query.page;// 使用 keyword 和 page 做相应的操作,例如进行搜索结果展示}
};

通过查询参数,你可以在 URL 中传递一些可选的参数,从而实现不同的页面展示和功能触发。

以上是处理带参数的路由的概念和用法,你可以根据你的具体需求选择合适的方式。

创建嵌套路由的结构和用法

嵌套路由是指在 Vue Router 中创建具有父子关系的路由结构。通过嵌套路由,你可以在应用程序中创建层次结构和组织路由,以更好地管理和展示你的页面。

下面是创建嵌套路由的结构和用法:

  1. 定义父路由和子路由:
    在路由配置中,可以定义父路由和子路由。父路由用于对应一个页面组件,而子路由则是该页面组件内的子组件的路由。
const router = new VueRouter({routes: [{path: '/users',component: Users,children: [{path: 'profile',component: UserProfile},{path: 'settings',component: UserSettings}]}]
});

在上述代码中,/users 是父路由的路径,对应的组件是 UsersUsers 组件内部有两个子组件的路由,即 /users/profile 对应 UserProfile 组件,/users/settings 对应 UserSettings 组件。

  1. 在父组件中设置 <router-view>
    在父路由对应的组件模板中,添加 <router-view> 指令来标记子组件的出口位置。
<!-- Users.vue -->
<template><div><h1>Users Page</h1><router-view></router-view> <!-- 子组件的路由将在此处渲染 --></div>
</template>

在上述代码中,<router-view> 指令将作为子组件路由的渲染位置。

  1. 切换子路由:
    在父组件的模板中,可以使用 <router-link> 组件来切换不同的子路由。
<!-- Users.vue -->
<template><div><h1>Users Page</h1><router-link to="/users/profile">Profile</router-link><router-link to="/users/settings">Settings</router-link><router-view></router-view></div>
</template>

在上述代码中,<router-link> 组件将显示为链接,点击链接将切换到对应的子路由。

通过以上步骤,你就可以创建一个嵌套路由的结构。当访问父路由时,父组件将显示,并在其内部的 <router-view> 处渲染对应的子组件。

相关文章:

超级英雄的导航之旅:动态路由和嵌套路由

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…...

发现个好玩的 Windows微信对话框换行

按住shift键按enter就是换行 直接按enter为发送...

Vue3最佳实践 第八章 ESLint 与 测试 ( Jest )

Jest 测试 Vue 组件 ​在前端项目开发过程中&#xff0c;有很多时候也会要进行测试工作。本文将重点介绍如何利用 JavaScript 测试框架 Jest 进行高效的测试。Jest 是由 FaceBook 开发的顶级测试框架之一&#xff0c;广受开发者们的欢迎和信赖。在接下来的内容中&#xff0c;我…...

【抓包分析】通过ChatGPT解密还原某软件登录算法实现绕过手机验证码登录

文章目录 &#x1f34b;前言实现效果成品广告抓包分析一、定位加密文件二、编辑JS启用本地替换 利用Chatgpt进行代码转换获取计划任务id模拟数据请求最后 &#x1f34b;前言 由于C站版权太多&#xff0c;所有的爬虫相关均为记录&#xff0c;不做深入&#xff01; 今天发现gith…...

【UE】属性同步,源码详解一个勾选了Actor复制的Actor第一次被创建时经历了什么

本文参考https://zhuanlan.zhihu.com/p/640723352 准备工作 先准备一个勾选了复制的Actor&#xff0c;然后在游戏开始时Spawn这个Actor 源码过程详解 发送属性同步 在NetDriver的TickFlush中发送属性同步的数据 1、ServerReplicateActors_BuildConsiderList 去找到所有需…...

Spring中Bean的完整生命周期!(Bean实例化的流程,Spring后处理器,循环依赖解释及解决方法)附案例演示

Bean实例化的基本流程 加载xml配置文件&#xff0c;解析获取配置中的每个的信息&#xff0c;封装成一个个的BeanDefinition对象将BeanDefinition存储在一个名为beanDefinitionMap的Map<String,BeanDefinition>中ApplicationContext底层遍历beanDefinitionMap&#xff0c…...

AcWing第 127 场周赛 - AcWing 5283. 牛棚入住+AcWing 5284. 构造矩阵 - 模拟+快速幂+数学

AcWing 5283. 牛棚入住 题目数据范围不大&#xff0c;直接暴力模拟即可 按照题目所说的意思即可。 #include <math.h> #include <stdio.h> #include <algorithm> #include <cstring> #include <iostream> using namespace std; const int N 1…...

2023-10-31 游戏开发-微信小游戏-文档记录

摘要: 2023-10-31 游戏开发-微信小游戏-文档记录 微信开发文档: 快速上手 | 微信开放文档 基础 | 微信开放文档 Cocos/Laya/Egret引擎适配 | 微信开放文档 cocos和微信平台相关文档: Cocos Creator 3.8 手册 - 发布到微信小游戏...

2023NOIP A层联测21-异或

给定一长度为 N N N 的由非负整数组成的数组 a a a&#xff0c;你需要进行一系列操作&#xff0c;每次操作选择一个区间 [ l , r ] [l,r] [l,r]&#xff0c;将 a [ l , r ] a_{[l,r]} a[l,r]​ 异或上 w w w。你需要将 a i a_i ai​ 全部变为 0 0 0。 求最小操作次数。…...

分布式存储系统Ceph应用组件介绍

1、 无中心架构分布式存储Ceph Ceph是一套开源的分布式存储系统。具有可靠性高&#xff0c;性能优良&#xff0c;可伸缩&#xff0c;与HDFS不同的地方在于&#xff0c;该架构中没有中心节点。 Ceph优点在于它不单单是存储&#xff0c;同时还充分利用了存储节点上的计算能…...

【数据结构】数组和字符串(十一):字符串的定义与存储(顺序存储、链式存储及其C语言实现)

文章目录 4.3 字符串4.3.1 字符串的定义与存储1. 顺序存储2. 链式存储3. C语言实现顺序存储4. C语言实现链式存储代码优化 4.3 字符串 字符串(String)是由零个或多个字符(char)顺序排列组成的有限序列&#xff0c;简称为串。例如 “good morning”就是由12个字符构成的一个字符…...

zk-Bench:SNARKs性能对比评估工具

1. 引言 JENS ERNSTBERGER等人2023年论文《zk-Bench: A Toolset for Comparative Evaluation and Performance Benchmarking of SNARKs》。 zk-Bench&#xff0c;定位为&#xff1a; 定位为首个公钥密码学性能评估基准测试框架和工具&#xff0c;重点关注通用ZKP系统的实测评…...

【Linux】NTP服务器配置、时间修改

查看当前系统时间date修改当前系统时间date -s "2018-2-22 19:10:30"查看硬件时间hwclock --show修改硬件时间hwclock --set --date "2018-2-22 19:10:30"同步系统时间和硬件时间hwclock --hctosys保存时钟clock –w1.设置NTP Server服务检查系统是否安装n…...

毕业设计基于SpringMVC+Mybatis+Bootstrap的电影院管理系统源码+数据库

<<电影院管理系统>> 电影院管理系统&#xff1a;SpringMVCJSPTomcatMybatisBootstrapJqueryAnimateCSSLayerJS 项目部署&#xff1a;该项目是IDEA版本&#xff0c;Maven项目 前端依赖&#xff1a; Bootstrap-3.4.1Animate.css- 4.1.1Jquery-3.6.0Layer-v3.5.1B…...

vantUI(Tabbar标签页)浏览器返回上一页的失效问题

在开发中遇到这样一个问题&#xff0c;由页面1切换到页面2&#xff0c;再点击浏览器的回退&#xff0c;无法回退到页面1。 开始以为是路由配置的有问题&#xff0c;但是子页面可以正常回退&#xff0c;因为replace只是替换路由&#xff0c;而不会往history栈中记录路由&#x…...

【算法】Prim算法(求最小生成树)

题目 给定一个 n 个点 m 条边的无向图&#xff0c;图中可能存在重边和自环&#xff0c;边权可能为负数。 求最小生成树的树边权重之和&#xff0c;如果最小生成树不存在则输出 impossible。 给定一张边带权的无向图 G(V,E)&#xff0c;其中 V 表示图中点的集合&#xff0c;E…...

go语言,yaml实现简单的workflow工作流

目录 1.创建一个yaml文件&#xff0c;名字可以是student.yaml 2.创建go文件测试 3.执行结果 本文章内容&#xff0c;只是一个简单的案例&#xff0c;但足够映射到一个大的项目中。 工作流作用&#xff1a;工作流的作用就是通过yaml配置文件&#xff0c;将关于本工作流的一个…...

BaiduMallServcie

说明 本文档指导业务开发步骤 BaiduMallServcie 说明一. 登录业务1.1 数据库设计1.1.1 管理员表1.1.2 角色表1.1.3 关联表 管理员表与角色表关联1.1.4 权限表1.1.5 关联表 角色表与权限表关联1.1.6 管理员登录日志表1.1.7 查询权限示例1.2 添加用户一. 登录业务 1.1 数据库设…...

vue3+jsx+antd的插槽写法之一

如果在jsx里面直接这样按照官方的写法是会报错的 正确写法是&#xff1a;...

Shell 学习之 if 命令

1. 执行流程 在 Shell 脚本中&#xff0c;if 是一个 控制流语句&#xff0c;用于进行条件判断&#xff0c;根据条件的结果执行相应的操作。 # 首先&#xff0c;Shell 会检查表达式 condition 返回的 boolean 值。 # 如果 condition 的值为真&#xff0c;则执行 then 代码块&a…...

戴森球计划FactoryBluePrints:解锁游戏工厂建造的终极免费蓝图库

戴森球计划FactoryBluePrints&#xff1a;解锁游戏工厂建造的终极免费蓝图库 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 还在为《戴森球计划》中复杂的工厂布局头疼吗&…...

Pyrene-PEG-Sil,芘丁酸酯聚乙二醇三乙氧基硅烷,荧光特性对微环境变化高度敏感

一.名称英文名称&#xff1a;Pyrene-PEG-Silane&#xff0c;Pyrene-PEG-Sil&#xff0c;Py-PEG-Silane&#xff0c;Py-PEG-Sil中文名称&#xff1a;芘丁酸酯聚乙二醇三乙氧基硅烷&#xff0c;芘丁酸酯-PEG-三乙氧基硅烷分子量&#xff1a;1k&#xff0c;2k&#xff0c;3.4k&…...

告别重复操作:用快马生成智能浏览器扩展,极速提升前端调试与数据提取效率

作为一名前端开发者&#xff0c;每天都要和网页元素打交道。调试样式、提取数据这些重复性工作&#xff0c;如果全靠手动操作&#xff0c;不仅效率低下还容易出错。最近我发现用InsCode(快马)平台可以快速生成定制化的浏览器扩展&#xff0c;把那些繁琐操作变成一键自动化&…...

Open UI5 源代码解析之736:CardBase.js

源代码仓库: https://github.com/SAP/openui5 源代码位置:src\sap.f\src\sap\f\CardBase.js CardBase.js 深度解析:在 OpenUI5 中承上启下的卡片基座 文件定位与整体判断 CardBase.js 位于 sap.f 库下,它不是面向业务开发者直接频繁实例化的组件,而是一个被多种卡片实…...

【Python并发革命】:GIL解除后首个生产级无锁插件生态正式开放下载(限时72小时)

第一章&#xff1a;Python并发革命的里程碑意义 Python 并发模型的演进并非渐进式改良&#xff0c;而是一场深刻重塑编程范式的革命。从早期依赖线程与锁的阻塞式模型&#xff0c;到 asyncio 的异步 I/O 抽象、async/await 语法糖的引入&#xff0c;再到结构化并发&#xff08;…...

PasteMD模板功能详解:创建个性化转换规则

PasteMD模板功能详解&#xff1a;创建个性化转换规则 你是不是经常从AI对话或者网页上复制内容到Word时&#xff0c;格式总是乱七八糟&#xff1f;公式变成乱码&#xff0c;表格错位&#xff0c;代码块失去高亮&#xff1f;PasteMD就是专门解决这个问题的神器&#xff0c;而它…...

热键冲突解决:从检测到修复的完整指南

热键冲突解决&#xff1a;从检测到修复的完整指南 【免费下载链接】hotkey-detective A small program for investigating stolen hotkeys under Windows 8 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 在日常电脑使用中&#xff0c;我们经常会遇到这…...

终极PDF批量处理指南:如何用PDF Arranger自动化文档操作

终极PDF批量处理指南&#xff1a;如何用PDF Arranger自动化文档操作 【免费下载链接】pdfarranger Small python-gtk application, which helps the user to merge or split PDF documents and rotate, crop and rearrange their pages using an interactive and intuitive gra…...

智能影像雅鉴系统:丹青识画在美术馆导览中的落地实操

智能影像雅鉴系统&#xff1a;丹青识画在美术馆导览中的落地实操 1. 艺术与科技的完美融合 1.1 传统导览的痛点与革新 在美术馆参观时&#xff0c;我们常常面临这样的困境&#xff1a;站在一幅名画前&#xff0c;却无法真正理解其深层意境&#xff1b;面对珍贵文物&#xff…...

AIVideo一站式AI长视频工具与Visual Studio的深度集成开发

AIVideo一站式AI长视频工具与Visual Studio的深度集成开发 1. 引言 作为一名长期使用Visual Studio进行开发的程序员&#xff0c;我经常遇到这样的痛点&#xff1a;想要录制一段代码演示视频&#xff0c;需要反复切换多个软件&#xff1b;想要制作项目介绍视频&#xff0c;得…...