详解Vue3中的基础路由和动态路由

本文主要介绍Vue3中的基础路由和动态路由。
目录
- 一、基础路由
- 二、动态路由
Vue3中的路由使用的是Vue Router库,它是一个官方提供的用于实现应用程序导航的工具。Vue Router在Vue.js的核心库上提供了路由的功能,使得我们可以在单页应用中实现页面的切换、跳转和参数传递等功能。
一、基础路由
下面是Vue3中使用Vue Router的步骤:
- 安装Vue Router:在命令行中运行以下命令来安装Vue Router。
npm install vue-router@next
- 创建路由实例:在你的Vue应用的入口文件中,创建一个Vue Router的实例。可以在
src目录下创建一个router.js文件,并在其中定义路由。
import { createRouter, createWebHistory } from 'vue-router'const router = createRouter({history: createWebHistory(),routes: [{path: '/',component: Home},{path: '/about',component: About}]
})export default router
这里使用createRouter函数来创建一个路由实例,createWebHistory函数用于创建一个基于HTML5 History API的路由模式。然后定义了两个路由,分别是根路径/和/about,对应的组件分别是Home和About。
- 在根组件中使用路由:在你的根组件(通常是
App.vue)中,使用router-view组件来渲染路由对应的组件。
<template><div><router-view></router-view></div>
</template>
- 配置路由链接:在你的应用中需要使用到路由链接的地方,使用
router-link组件来创建链接。
<template><nav><router-link to="/">Home</router-link><router-link to="/about">About</router-link></nav>
</template>
这里使用to属性来指定链接的路径。
- 在Vue实例中使用路由:在创建Vue实例时,将路由实例作为
router选项传入。
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'createApp(App).use(router).mount('#app')
以上就是在Vue3中使用Vue Router的基本步骤。除了以上基本的使用方法之外,Vue Router还提供了许多高级功能,如动态路由、嵌套路由、路由守卫等。
二、动态路由
在Vue3中,动态路由是指根据不同的参数生成不同的路由。使用动态路由可以实现根据传入的参数渲染不同的页面或组件,从而实现根据用户选择或输入的不同内容展示不同的结果。
以下是在Vue3中使用动态路由的示例:
- 定义动态路由:在创建路由实例时,可以使用动态的路径参数来定义路由。
import { createRouter, createWebHistory } from 'vue-router'const router = createRouter({history: createWebHistory(),routes: [{path: '/user/:id',component: User}]
})export default router
在上面的代码中,我们使用了路径参数:id来定义动态的路由。这样,当访问/user/1时,就会匹配到该路由,并渲染对应的User组件。
- 在组件中接收参数:在动态路由所对应的组件中,可以通过
$route对象来获取传入的参数。
<template><div>User ID: {{ $route.params.id }}</div>
</template>
在上面的代码中,我们使用了$route.params.id来获取传入的参数。在访问/user/1时,就会显示User ID: 1。
- 更新动态路由:如果需要在同一个路由路径下根据不同的参数重新渲染组件,可以使用Vue Router提供的
beforeRouteUpdate守卫。
<template><div>User ID: {{ $route.params.id }}</div>
</template><script>
export default {beforeRouteUpdate(to, from, next) {// 更新组件数据this.loadData(to.params.id)next()},methods: {loadData(id) {// 根据id加载数据// ...}}
}
</script>
在上面的代码中,我们使用beforeRouteUpdate守卫来监听路由的变化,在路由切换时调用loadData方法更新组件的数据。
通过上述步骤就可以在Vue3中使用动态路由来实现根据不同的参数生成不同的路由,并在组件中接收参数和更新数据。这样可以灵活地根据用户的输入或选择来呈现不同的内容。
在Vue3中使用动态路由时,有一些需要注意的地方:
-
路由定义的顺序:在定义路由时,要注意路由的顺序。动态路由的定义应该放在静态路由的后面,以确保正确匹配路由。
-
动态路由的参数类型:动态路由的参数可以是任意类型,但是在路由定义时需要明确指定参数的类型。例如,使用路径参数时,可以使用
/user/:id来定义一个动态的id参数,但是需要注意参数类型是字符串。 -
监听路由变化:在动态路由所对应的组件中,可以使用
beforeRouteUpdate守卫来监听路由的变化,并在路由切换时执行相应的操作。 -
参数传递:可以通过路径参数、查询参数、props等方式将参数传递给动态路由所对应的组件。具体的传递方式可以根据实际需求选择。
-
路由参数的访问:在动态路由所对应的组件中,可以通过
$route.params来访问传递的路径参数,通过$route.query来访问查询参数。 -
动态路由的变化触发:动态路由参数的变化可能不会触发组件的重新渲染,需要手动监听参数的变化,并在变化时执行相应的操作。
以上是在Vue3中使用动态路由时需要注意的一些地方。合理地使用动态路由可以增加路由的灵活性,实现根据不同参数展示不同内容的功能。
相关文章:
详解Vue3中的基础路由和动态路由
本文主要介绍Vue3中的基础路由和动态路由。 目录 一、基础路由二、动态路由 Vue3中的路由使用的是Vue Router库,它是一个官方提供的用于实现应用程序导航的工具。Vue Router在Vue.js的核心库上提供了路由的功能,使得我们可以在单页应用中实现页面的切换、…...
Mysql四种事务隔离级别(简易理解)
读未提交:简单理解就是读到没有提交事务的执行结果;读已提交:简单理解就是只能读到已经提交的事务执行结果;可重复读:简单理解就是确保并发读取数据库时,读到的数据一致,这是mysql默认隔离级别&…...
react中使用redux最简单最方便的方式,配合rematch简化操作,5分钟学会
react中使用状态管理的方式也很多,比如redux和mobx等,今天这一片就讲一下redux的入门到熟练使用,主要是要理解它redux的组成有哪些,到怎么创建,和组建中怎么使用三个问题。这里先放上官网文档,不理解的地方…...
vmware安装中标麒麟高级服务器操作系统软件 V7.0操作系统
vmware安装中标麒麟高级服务器操作系统软件 V7.0操作系统 1、下载中标麒麟高级服务器操作系统软件 V7.0镜像2、安装中标麒麟高级服务器操作系统软件 V7.0操作系统 1、下载中标麒麟高级服务器操作系统软件 V7.0镜像 官方提供使用通道 访问官网 链接: https://www.kylinos.cn/ 下…...
OpenCV | 霍夫变换:以车道线检测为例
霍夫变换 霍夫变换只能灰度图,彩色图会报错 lines cv2.HoughLinesP(edge_img,1,np.pi/180,15,minLineLength40,maxLineGap20) 参数1:要检测的图片矩阵参数2:距离r的精度,值越大,考虑越多的线参数3:距离…...
【C#与Redis】--目录
1. 介绍 2. Redis 数据结构 3. Redis 命令 3.1 基本命令 3.2 字符串命令 3.3 哈希命令 3.4 列表命令 3.5 集合命令 3.6 有序集合命令 4. C# 操作 Redis 4.1 使用 Redis 库 4.2 连接 Redis 服务器 4.3 操作 Redis 数据结构 4.5 执行 Redis 命令 5. 高级主题 5.1 Redis 事…...
html旋转相册
一、实验题目 做一个旋转的3d相册,当鼠标停留在相册时,相册向四面散开 二、实验代码 <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" con…...
Plantuml之对象图语法介绍(十九)
简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒…...
深度学习(八):bert理解之transformer
1.主要结构 transformer 是一种深度学习模型,主要用于处理序列数据,如自然语言处理任务。它在 2017 年由 Vaswani 等人在论文 “Attention is All You Need” 中提出。 Transformer 的主要特点是它完全放弃了传统的循环神经网络(RNN&#x…...
R语言中的函数28:Reduce(), Filter(), Find(), Map(), Negate(), Position()
文章目录 介绍Reduce()实例 Filter()实例 Find()实例 Map()实例 Negate()实例 Position()实例 介绍 R语言中的Reduce(), Filter(), Find(), Map(), Negate(), Position()是base包中的一些高级函数。随后,很多包也给这些函数提供了更多的扩展。 Reduce() 该函数根…...
RTP/RTCP/RTSP/SIP/SDP/RTMP对比
RTP(Real-time Transport Protocol)是一种用于实时传输音频和视频数据的协议。它位于传输层和应用层之间,主要负责对媒体数据进行分包、传输和定时。 RTCP(Real-Time Control Protocol)是 RTP 的控制协议,…...
Centos安装vsftpd:centos配置vsftpd,ftp报200和227错误
一、centos下载安装vsftpd(root权限) 1、下载安装 yum -y install vsftpd 2、vsftpd的配置文件 /etc/vsftpd.conf 3、备份原来的配置文件 sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.backup 4、修改配置文件如下:vi /etc/vsftpd.conf …...
软件测试职业规划
软件测试人员的发展误区【4】 公司开发的产品专业性较强,软件测试人员需要有很强的专业知识,现在软件测试人员发展出现了一种测试管理者不愿意看到的景象: 1、开发技术较强的软件测试人员转向了软件开发(非测试工具开发); 2、业务…...
C语言数据结构
C 语言是一种强大的编程语言,它提供了许多数据结构的实现。在本文档中,我们将讨论一些常见的数据结构,并提供相应的代码示例。 数组(Array) 数组是一种线性数据结构,它可以存储相同类型的元素。数组的大小…...
PHP之Trait理解, Trait介绍
一、来源 自 PHP 5.4.0 起,PHP 实现了一种代码复用的方法,称为 trait。 Trait 是为类似 PHP 的单继承语言而准备的一种代码复用机制。Trait 为了减少单继承语言的限制,使开发人员能够自由地在不同层次结构内独立的类中复用 method。Trait 和…...
SpringMVC:执行原理详解、配置文件和注解开发实现 SpringMVC
文章目录 SpringMVC - 01一、概述二、SpringMVC 执行原理三、使用配置文件实现 SpringMVC四、使用注解开发实现 SpringMVC1. 步骤2. 实现 五、总结注意: SpringMVC - 01 一、概述 SpringMVC 官方文档:点此进入 有关 MVC 架构模式的内容见之前的笔记&a…...
增量式旋转编码器在STM32平台上的应用
背景 旋钮是仪器仪表上一种常见的输入设备,它的内部是一个旋转编码器,知乎上的这篇科普文章对其工作原理做了深入浅出的介绍。 我们公司的功率分析仪的前面板也用到了该类设备,最近前面板的MCU从MSP430切换成了STM32,因此我要将…...
INFINI Gateway 如何防止大跨度查询
背景 业务每天生成一个日期后缀的索引,写入当日数据。 业务查询有时会查询好多天的数据,导致负载告警。 现在想对查询进行限制–只允许查询一天的数据(不限定是哪天),如果想查询多天的数据就走申请。 技术分析 在每…...
【模式识别】探秘分类奥秘:最近邻算法解密与实战
🌈个人主页:Sarapines Programmer🔥 系列专栏:《模式之谜 | 数据奇迹解码》⏰诗赋清音:云生高巅梦远游, 星光点缀碧海愁。 山川深邃情难晤, 剑气凌云志自修。 目录 🌌1 初识模式识…...
【Redis】分布式锁
目录 分布式锁分布式锁实现的关键 Redisson实现分布式锁看门狗机制 分布式锁 为什么要使用分布式锁,或者分布式锁的使用场景? 定时任务。在分布式场景下,只控制一台服务器执行定时任务,这就需要分布式锁 要控制定时任务在同一时间…...
华硕笔记本性能控制终极指南:告别臃肿,拥抱G-Helper轻量化革命
华硕笔记本性能控制终极指南:告别臃肿,拥抱G-Helper轻量化革命 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vi…...
Twitter数据抓取实战:x-twitter-scraper混合架构与生产环境部署指南
1. 项目概述:一个高效、稳定的Twitter数据抓取利器如果你正在寻找一个能绕过官方API限制,稳定、高效地抓取Twitter(现X平台)数据的工具,那么x-twitter-scraper这个开源项目绝对值得你花时间深入研究。它不是一个简单的…...
如何在Windows系统上一键部署终极包管理器:winget安装工具完全指南
如何在Windows系统上一键部署终极包管理器:winget安装工具完全指南 【免费下载链接】winget-install Install WinGet using PowerShell! Prerequisites automatically installed. Works on Windows 10/11 and Server 2019/2022. 项目地址: https://gitcode.com/gh…...
如何用 curl 命令快速测试 Taotoken 的 API 是否连通
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 如何用 curl 命令快速测试 Taotoken 的 API 是否连通 在接入大模型服务时,直接使用 curl 命令测试 API 是最基础、最直…...
我的技术博客从0到月入过万,用了这五个变现路径
很多测试同行问我:“每天写测试用例、提Bug、做自动化,这些重复性的工作内容,真能写成文章还有人看?”我的答案是:不仅能,而且测试人做技术博客,有着其他岗位难以复制的独特优势。因为我们每天都…...
LLM资源库:大语言模型开发者的高效导航与实战指南
1. 项目概述:一个汇聚LLM资源的“藏宝图”在人工智能,特别是大语言模型(LLM)领域,技术迭代的速度快得让人眼花缭乱。每天都有新的模型发布、新的工具开源、新的论文发表。对于开发者、研究者甚至是刚入门的学习者来说&…...
从手机SoC到汽车芯片:深入聊聊AMBA总线家族(AHB/APB/AXI)的选型与实战踩坑
从手机SoC到汽车芯片:AMBA总线家族的选型与实战经验 在移动计算和汽车电子两大领域,芯片架构师们每天都在面临类似的挑战:如何在有限的硅片面积和功耗预算内,实现最高的系统性能。AMBA总线作为连接处理器、内存和各种外设的"…...
国密SM2的P7格式签名,和PKCS#7到底有啥区别?一张图讲清楚
国密SM2的P7格式签名与PKCS#7核心差异解析:从结构到实战 在密码学应用开发中,数字签名格式的标准化是实现安全通信的基础。当开发者从国际通用的PKCS#7标准转向中国自主研发的国密SM2算法体系时,P7签名格式的差异往往成为第一个需要跨越的技术…...
水凝膜、钢化膜、护景贴大对决:一张表看懂该买谁
水凝膜、钢化膜、护景贴大对决:一张表看懂该买谁手机屏幕保护膜主要有三种:水凝膜、普通钢化膜和护景贴(悟赫德为代表)。很多人不知道它们到底有什么区别,我们从六个维度给你讲清楚。材料结构。水凝膜是单层软塑料&…...
win2xcur:Windows光标主题完美移植Linux的格式转换指南
1. 项目概述:从Windows光标到Linux的“翻译官”如果你和我一样,是个在Linux桌面和Windows之间反复横跳的用户,或者你为团队维护着跨平台的开发环境,那你一定遇到过这个不大不小但很恼人的问题:Windows系统上那些精心设…...
