位置: IT常识 - 正文

Vue Router4 ,prams 传参失效和报错问题

编辑:rootadmin
Vue Router4 ,prams 传参失效和报错问题 Vue3 使用 Vue Router 时,prams 传参失效和报错问题

推荐整理分享Vue Router4 ,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>Vue Router4 ,prams 传参失效和报错问题

将参数放在 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.paramsconsole.log('history.state', history.state)</script>

本文链接地址:https://www.jiuchutong.com/zhishi/298565.html 转载请保留说明!

上一篇:性能优化之-事件代理(性能优化有什么用)

下一篇:OpenAI发布GPT-4;目前最完整的ChatGPT资源库;中文版提示词工程指南;AI颠覆播客体验;ChatGPT引发的10大职业危机 | ShowMeAI日报(openai发布时间)

  • 苹果搜索页面怎么关闭(苹果搜索页面怎么设置自己想要的)

  • 快手商家号和个人号的区别(快手商家号个人介绍怎么写)

  • 红米内容中心怎么关闭(红米内容中心怎么关闭广告)

  • ai dual camera水印是什么手机(ai triple camera水印)

  • 显示器边缘显示不全(显示器边缘显示不清楚)

  • 瓦片电机和普通电机有什么区别(瓦片电机和普通电机哪个好)

  • 物联卡换另一个手机(物联卡换另一个手机怎么不能用了)

  • 手机摔了屏幕没坏黑屏(手机摔了屏幕没反应怎么办)

  • sarifi浏览器无法打开网页(sarifi浏览器无法打开网页,因为无法连接服务器)

  • 手机屏幕出现小方块带(手机屏幕出现小黑点)

  • 华为手机位置权限在哪里打开(华为手机位置权限访问记录怎么删除)

  • 抖音小店只有电脑才能管理吗(抖音小店只能在直播中呈现吗)

  • gtxtitanx是游戏显卡吗

  • 胶卷相机是什么意思(胶卷相机是什么原理)

  • 苹果XR系列和苹果11系列区别(苹果xr与苹果)

  • iphone锁屏上滑不出控制中心(苹果手机锁屏上滑不动)

  • 苹果xr卡槽哪个是主卡(苹果xr卡槽哪个放电信好)

  • 华为荣耀20自带钢化膜吗(华为荣耀20自带浏览器是哪个)

  • 苹果录屏功能没有声音(苹果录屏功能没声音)

  • wps里横线怎么打出来(wps里横线怎么打出来手机)

  • 2019qq群名片在哪(qq里的群名片是什么)

  • 键盘上用什么代替fn键(键盘上用什么代替鼠标好)

  • 防沉迷怎么修改

  • 小米6无线充电设置(小米6无线充电吗)

  • naver怎么改中文(naver怎么设置中文)

  • oppo手机分享热点怎么用(oppo手机分享热点怎么操作)

  • oppoa9x是什么处理器(oppoa9x参数什么处理器)

  • 记录-安装cuda与cudnn 及对应版本的tensorflow|pytorch(安装cuda和cudnn)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络