【vue3|第25期】Vue3中的useRoute:轻松访问路由信息

news/2024/10/22 14:39:37/

日期:2024年8月21日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉在这里插入代码片有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006

说在最前面:本文 vue3 的示例代码,在没有另外声名的情况下,均采用 <script setup> 组合式代码风格,风格统一,避免混乱,请各位新老食客放心食用哈 ^ _ ^


文章目录

  • 一、前言
  • 二、useRoute 的前世今生?
  • 三、`useRoute` 的属性
  • 三、实战应用:使用 useRoute 获取路由信息
    • 示例:动态路由与查询参数
  • 四、结语


在这里插入图片描述


一、前言


Vue3 中,组合式 APIComposition API)提供了一种更加灵活和直观的方式来组织和复用逻辑。其中,useRouteVue Router 4 中的一个强大工具,它允许我们在 setup 函数、语法糖中轻松访问当前路由的信息。本文将详细介绍 useRoute 的用法、属性和方法,并通过实例展示如何在实际项目中应用它。

二、useRoute 的前世今生?


Vue2 中,我们通过 this.$route 来访问路由信息,但到了 Vue3Composition API 的出现使得我们有了更加现代的解决方案 —— useRoute

useRouteVue Router4(适用于 Vue3)中的一个 Composition API 函数。它提供了一种简洁的方式来访问当前激活路由的状态,包括路径、参数、查询参数等,更符合组合式 API 的方式,提供了一个响应式的 route 对象,使得数据操作更加直观和高效。

另外,通过 useRoute,我们可以避免在组件中直接访问全局的 $route 对象,从而使代码更加模块化和可维护。

三、useRoute 的属性


当我们在组件的 setup 函数中调用 useRoute 时,它会返回一个响应式的 route 对象。这个对象包含了当前路由的各种信息,如路径、名称、参数、查询参数等。

  • path:当前路由的路径,如 /about。
  • params:对象,当前路由的参数,例如 { id: ‘123’ }。
  • query:对象,当前路由的查询参数,如 { sort: ‘newest’ }。
  • fullPath:当前路由的完整路径,包括查询参数。
  • meta:对象,当前路由的元信息。
  • name:当前路由的名称,如果有的话。
  • hash:当前路由的哈希值(带 #)。
  • matched:数组,当前路由匹配的路径段的路由记录。

三、实战应用:使用 useRoute 获取路由信息


Vue3 组件的 <script setup> 标签中,使用 useRoute 变得异常简单:

javascript"><script setup>
import { useRoute } from 'vue-router';
const route = useRoute();console.log(route.path);      // 输出当前路径
console.log(route.params);    // 输出当前路由参数
console.log(route.query);     // 输出当前路由查询参数
</script>

示例:动态路由与查询参数

假设我们有这样一个路由配置:

javascript">const routes = [{path: '/user/:id',name: 'user',component: UserComponent,// 更多路由配置...},// 更多路由配置...
];

UserComponent 组件中,我们可以通过 useRoute 来访问动态参数和查询参数:

javascript"><script setup>
import { useRoute } from 'vue-router';
const route = useRoute();// 动态输出用户 ID
const userId = route.params.id;
console.log("userId:", userId);// 后续逻辑代码省略...</script>

通过上述代码,你将能够轻松获取和利用动态参数 :id 的值,从而实现动态渲染组件内容或执行相应逻

更多传参相关知识,可看我的另一篇博客《Vue-Router路由的三种传参方式》

四、结语


useRoute 的出现,不仅简化了我们在 Vue3 中获取和操作当前路由信息的过程,还使得代码变得更加响应式和可维护。掌握 useRoute,你就能在 Vue3 的项目中更加得心应手地处理动态路由,实现更加灵活和高效的应用开发。


参考文章:

  • 《Vue Router官方文档》
  • 《Vue 组合式 API 常见问答》

版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/141390994


http://www.ppmy.cn/news/1514585.html

相关文章

(QT-UI)十三、通过定时器,实时更新时间轴

本系列预计实现 ①刻度上方文字显示&#xff0c; ②时间轴拖动效果&#xff0c; ③时间轴刻度缩放&#xff0c; ④时间轴和其他控件联动显示&#xff0c; ⑤鼠标放置到时间轴&#xff0c;显示具体时间。 ⑥通过定时器&#xff0c;实时更新时间轴 ⑦时间轴上绘制时间片 完…

使用Python编辑文件属性

一、使用Python设置文件的访问和修改时间 import os import time# 获取当前时间 now time.time()# 设置文件的访问和修改时间 os.utime(test.txt, (now, now)) os.utime(path, &#xff08;time1&#xff0c;time2&#xff09;) 参数解析 path&#xff1a;表示文件路径 ti…

PDF Shaper Ultimate v14.4 中文授权版

PDF Shaper是一款处理PDF的软件。PDF Shaper的功能有&#xff1a;合并&#xff0c;分割&#xff0c;加密和解密 PDF&#xff0c;图像转换为 PDF&#xff0c;PDF 转换为 RTF 或 图像&#xff0c;从 PDF 中提取文本和图像。 该版本已授权&#xff0c;可以免费使用。 软件截图&a…

每天一个数据分析题(四百八十八)- 非监督学习

关于非监督学习&#xff0c;在K-means聚类分析使用的距离是&#xff08; &#xff09; A. 欧式距离 B. 绝对距离 C. Minkowski距离 D. 笛卡尔距离 数据分析认证考试介绍&#xff1a;点击进入 题目来源于CDA模拟题库 点击此处获取答案 数据分析专项练习题库 内容涵盖Pyt…

K8s节点状态 NotReady排查

k8s节点由 Ready变成 NotReady izbp12ghzy6koox6fqt0suz NotReady slave 97d v1.23.3 izbp12ghzy6koox6fqt0svz Ready control-plane,master 98d v1.23.3节点进入 NotReady 状态可能是由于多种原因引起的&#xff0c;尤其是在资源过量分配&am…

Selenium工具使用Python实现下拉框定位操作

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 我们通常遇到的下拉框有显性的下拉框和隐性的下拉框&#xff1b;有的下拉框还可以进行单选或多选操作&#xff0c;在selenium中如何实现下拉框的定位通常使用selec…

未来的社交网络:人工智能如何推动Facebook的发展

在当今数字化飞速发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;已成为推动各行业进步的核心动力之一。社交媒体巨头Facebook凭借其在人工智能领域的深厚积累&#xff0c;正逐步将AI技术融入平台的各个方面&#xff0c;重新定义用户体验&#xff0c;并引领社交网络…

禁止浏览器默认填充密码 vue

禁止浏览器默认填充密码会和我的样式冲突 所以禁止 第一种&#xff1a; 通过给表单元素添加 autocomplete"off" 属性&#xff0c; 可以防止浏览器自动填充表单中的账号和密码。可以在 input 标签或整个 form 标签上使用&#xff1a; <template><a-form&g…