位置: 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发布时间)

  • 收到其他与经营活动有关的现金是什么意思
  • 配件销售过程中有什么注意事项
  • 计提坏账准备的做法体现了
  • 建筑业普票和专票的比例
  • 企业流动资产周转率下降的原因
  • 公司出售固定资产
  • 金税盘开完票后怎么报税一下
  • 用友软件在哪里
  • 物业公司销售门禁卡属于什么收入
  • 保险柜库存现金留存不能超过多少
  • 营改增是什么时候提出的
  • 品牌管理费是否交增值税
  • 过路过桥费抵扣2021新规定
  • 出让方式取得土地使用权会计处理
  • 法人往公户转账需要备注吗
  • 电子银行承兑汇票如何贴现
  • 公司一般户要做账吗
  • 专利代理费如何报销
  • 华硕主板如何刷系统
  • 如何使用ping命令诊断网络故障
  • macbook上安装windows10
  • 差旅费账务处理例子
  • 合并报表的范围
  • 红字增值税专用发票是什么
  • php下载限速
  • 未分配利润转增股本交印花税
  • php封装app
  • 详解HTTP Cookie状态管理机制
  • 在途物资属于什么存货
  • wordpresscom
  • php类型转换的两种方法
  • 非关联企业借款利息扣除
  • elasticsearch基本概念
  • mysql左连接查询 效率
  • 融资租赁业务应包括哪些
  • 软件行业的成本核算
  • 增值税进项发票勾选认证流程
  • 会计中的明细科目是什么
  • 企业非流动资产包括
  • 支付的物业费如何做账
  • 去年暂估费用,今年收到发票怎么处理
  • 企业每月利润多少合适
  • 委托代销商品支付的手续费计入销售费用吗
  • 产品成本计算中最基本的方法是
  • 可供出售金融资产包括哪些内容
  • 存货报废计入
  • 固定资产售后回购
  • 不能抵扣的会计分录
  • 会计分录借贷怎么分视频教程
  • sedsvc.exe是什么
  • 控制windows外观和工作方式
  • googletoolbarnotifier.exe是什么进程?GoogleToolbarNotifier怎么关闭?
  • 新买的u盘安全吗
  • mac无法开机怎么办
  • winxp如何将桌面文件默认到d盘
  • 苹果Mac系统怎么切换输入法
  • retrorun.exe - retrorun有什么用 是什么进程
  • u盘背景图片设置方法
  • win8windows设置在哪里
  • win11连接win7共享打印机
  • 2016年微软股价
  • win8文件夹打不开
  • 网站出现问题怎么办
  • win7怎么禁用软件
  • win10资源管理器启动不了
  • cocos2dx 3.17
  • opengl英文
  • python中requests库session对象的妙用详解
  • python写一个备份文件功能
  • unity每秒执行一次
  • shell脚本编程实例
  • 国家税务总局公告2022年第9号
  • 扣缴个人所得税怎么算
  • 河北电子税务局网上登录
  • 北京市税务局的待遇怎么样
  • 武汉税务局官网查询系统
  • 长期挂账的其他应付款的规定
  • 河北省税金费率
  • 小微企业所得税优惠政策最新2023
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设