首页IT科技vue router怎么传值(Vue Router4 ,prams 传参失效和报错问题)

vue router怎么传值(Vue Router4 ,prams 传参失效和报错问题)

时间2025-05-01 21:41:42分类IT科技浏览8564
导读:Vue3 使用 Vue Router 时,prams 传参失效和报错问题...

Vue3 使用 Vue Router 时                ,prams 传参失效和报错问题

我尝试使用 prams 传递数据

<script setup> import { useRouter } from vue-router const router = useRouter() const params = { id: 1, name: ly, phone: 13246566476, age: 23 } const toDetail = () => router.push({ name: detail, params }) </script> <template> <el-button type="danger" @click="toDetail">查看情页</el-button> </template>

在接收页面尝试渲染 prams 传递的数据:

<template> <div>姓名:{{ route.params?.name }}</div> <div>电话:{{ route.params?.phone }}</div> <div>年龄:{{ route.params?.age }}</div> </template> <script setup> import { useRoute } from vue-router const route = useRoute() </script>

当我跳转页面时,得到的 prams 数据为空 ,控制台也出现了 Vue Router 的警告

点开链接后发现了原因, 点击查看更新日志

也就是说                         ,从Vue Router的2022-8-22 这次更新后        ,我们使用上面的方式在新页面无法获取:

vue也给我们提出了代替方案:

使用 query 的方式传参

只要改成query 传参就好了,注意query传参只能用路由表中的 path ,不是 name ,并且所有参数都会显示在URL 地址上                 。

<script setup> import { useRouter } from vue-router const router = useRouter() const query = { id: 1, name: ly, phone: 13246566476, age: 23 } const toDetail = () => router.push({ path: /detail, query }) </script> <template> <el-button type="danger" @click="toDetail">查看情页</el-button> </template>

将参数放在 pinia 或 vuex仓库里

使用动态路由匹配

传递 state        ,在新页面使用 History API 接收参数

使用 meta 原信息方式传递 (此方式更适用于路由守卫)

使用动态路由匹配

如果传递参数较少的情况下                         ,可以尝试使用下面这种方式                ,只要修改一下path定义部分就可以了:

// params 传递的参数: { id: 1, name: ly, phone: 13246566476, age: 23 } { path: /detail/:id/:name/:phone/:age, name: detail, component: () => import(@/views/detail/index.vue) }

查看页面效果        ,控制台警告也消失了:

注意                         ,如果使用使用了这种动态路由匹配方式                , path: /detail/:id/:name/:phone/:age ,中这三个参数你都必须传递,否则会报错:

个人觉得这么写很鸡肋: 如果不把params参数写在路由路径中无法得到 params 参数                         ,这种方式的params参数又会显示在地址栏                        。虽然不算弃用params, 但是每次把params参数写在路由路径中是很麻烦的一件事        。

使用HistoryAPI方式传递和接收

在跳转前的页面使用 state 参数:

<script setup> import { useRouter } from vue-router const router = useRouter() const params = { id: 1, name: ly, phone: 13246566476, age: 23 } const toDetail = () => router.push({ name: detail, state: { params } }) </script> <template> <el-button type="danger" @click="toDetail">查看情页</el-button> </template>

跳转的后页面接收:

<template> <div>{{ historyParams }}</div> </template> <script setup lang="ts"> const historyParams = history.state.params console.log(history.state, history.state) </script>

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
青橙手机怎么样好用吗(青橙 GO M3 3G手机(珍珠黑)WCDMA/GSM 双卡双待 360特供机高通胶水双核,A5老架构,内存缩水,,,强烈要求降价) 提升百度移动端关键词排名价格(提升网站排名,百度SEO关键词排名优化软件助力你的网站腾飞!)