栽Vue3中传递路由参数的三种方式
作者:ksuper&
vue 路由传参的使用场景一般都是应用在父路由跳转到子路由时,携带参数跳转,传参方式可划分为 params 传参和 query 传参,本文将给大家介绍如何通过不同方式在 Vue 3 中传递路由参数,需要的朋友可以参考下
如何通过不同方式在 Vue 3 中传递路由参数,并在组件中使用 defineProps 或其他组合式 API 获取这些参数?
1. 通过 path 参数传递
最常见的方式,通过在路由路径中定义动态参数,并在路由配置中设置 props: true,将参数作为 props 传递给组件。
路由配置
{ path: '/:projectId(\\d+)/report/calc/:reportId(\\d+)', name: 'CreateCalcPage', component: () => import('@/pages/report/calc.vue'), props: true, // 通过 props 传递路由参数 }
组件中使用 defineProps
<template> <div> <p>Project ID: {{ projectId }}</p> <p>Report ID: {{ reportId }}</p> </div> </template> <script setup> import { defineProps } from 'vue'; const props = defineProps({ projectId: { type: String, required: true, }, reportId: { type: String, required: true, }, }); </script>
2. 通过 query 参数传递
可以通过 query
参数传递数据。在这种情况下,需要手动从 route
对象中获取参数。
路由跳转
router.push({ name: 'CreateCalcPage', query: { projectId: '123', reportId: '456', }, });
组件中使用 useRoute
<template> <div> <p>Project ID: {{ projectId }}</p> <p>Report ID: {{ reportId }}</p> </div> </template> <script setup> import { useRoute } from 'vue-router'; const route = useRoute(); const projectId = route.query.projectId; const reportId = route.query.reportId; </script>
3. 通过 props 选项传递
可以在路由配置中使用 props
选项来传递静态或动态参数。
静态参数
{ path: '/report/calc', name: 'CreateCalcPage', component: () => import('@/pages/report/calc.vue'), props: { projectId: '123', reportId: '456' }, }
动态参数
{ path: '/report/calc', name: 'CreateCalcPage', component: () => import('@/pages/report/calc.vue'), props: route => ({ projectId: route.query.projectId, reportId: route.query.reportId }), }
组件中使用 defineProps
<template> <div> <p>Project ID: {{ projectId }}</p> <p>Report ID: {{ reportId }}</p> </div> </template> <script setup> import { defineProps } from 'vue'; const props = defineProps({ projectId: { type: String, required: true, }, reportId: { type: String, required: true, }, }); </script>
总结
- 通过
path
参数传递:在路由路径中定义动态参数,并使用props: true
将其作为 props 传递。 - 通过
query
参数传递:在路由跳转时通过query
参数传递数据,并在组件中使用useRoute
获取。 - 通过
props
选项传递:在路由配置中使用props
选项传递静态或动态参数。
到此这篇关于栽Vue3中传递路由参数的三种方式的文章就介绍到这了,更多相关Vue3传递路由参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!