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

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

日期: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 变得异常简单:

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

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

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

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

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

<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.mrgr.cn/news/5816.html

相关文章:

  • Baumer工业相机堡盟工业相机如何通过BGAPISDK初始化时过滤其它非Baumer相机(C++)
  • 实时手势识别(2)- 基于关键点分类实现零样本图片的任意手势的识别
  • 大数据面试-Zookeeper
  • Stable Diffusion【应用篇】【艺术写真】:超高相似度人物换脸写真,IP-Adapter与InstantID完美结合
  • docker安装mysql使用宿主机网络
  • vue3模拟生成并渲染10万条数据,并实现本地数据el-table表格分页
  • Ant-Design-Vue快速上手指南+排坑
  • IPO雷达丨具备独特产业链布局优势,港迪技术成长性较强
  • 我的新项目又来咯!
  • 超低排放验收流程的全方位指南
  • 为什么企业跨国组网建议用SD-WAN?
  • 前端宝典十二:node基础模块和常用API
  • 每日一问:为什么MySQL索引使用B+树? 第4版 (含时间复杂度对比表格)
  • 一NULL为甚?
  • Redis管道
  • 提升代码可读性的十八条建议2
  • LNMP学习
  • C学习(数据结构)--> 实现顺序结构二叉树
  • 在亚马逊云科技上提取视频内容并利用AI大模型开发视频内容问答服务
  • 海山数据库(He3DB)源码详解:CommitTransaction函数源码详解