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

  • 淘宝网店的宣传推广决定你开网店的成败(淘宝网店宣传推广)

    淘宝网店的宣传推广决定你开网店的成败(淘宝网店宣传推广)

  • ios15小白点怎么开(苹果小白点怎么设置ios15)

    ios15小白点怎么开(苹果小白点怎么设置ios15)

  • 华为p40pro可以注视不熄屏吗(华为p40怎么注册)

    华为p40pro可以注视不熄屏吗(华为p40怎么注册)

  • 腾讯课堂分屏情况下算时间吗(腾讯课堂分屏可以看到吗)

    腾讯课堂分屏情况下算时间吗(腾讯课堂分屏可以看到吗)

  • 一个光猫接两个路由器怎么设置(一个光猫接两个路由器怎么接图片)

    一个光猫接两个路由器怎么设置(一个光猫接两个路由器怎么接图片)

  • 修改微信号的条件(修改微信号的条件怎么满足)

    修改微信号的条件(修改微信号的条件怎么满足)

  • 可以在多个平台抢票吗(可以在多个平台直播吗?)

    可以在多个平台抢票吗(可以在多个平台直播吗?)

  • 华为手机隐私空间占内存吗(华为手机隐私空间密码忘了怎么办)

    华为手机隐私空间占内存吗(华为手机隐私空间密码忘了怎么办)

  • 音频dac是什么意思(音频dac工作原理)

    音频dac是什么意思(音频dac工作原理)

  • 支付宝只能集一个五福(支付宝只能集一套福卡吗)

    支付宝只能集一个五福(支付宝只能集一套福卡吗)

  • 红米note9pro上市时间(红米note9pro上市时间及价格)

    红米note9pro上市时间(红米note9pro上市时间及价格)

  • 淘气值799还能涨吗(淘气值从799开始下降是什么情况)

    淘气值799还能涨吗(淘气值从799开始下降是什么情况)

  • 微信只能发信息不能收信息怎么回事(微信只能发信息不能打电话怎么回事)

    微信只能发信息不能收信息怎么回事(微信只能发信息不能打电话怎么回事)

  • 屏幕时间密码可以输错几次(屏幕时间密码可以破解吗)

    屏幕时间密码可以输错几次(屏幕时间密码可以破解吗)

  • iphonex切换控制怎么用(iphonex切换控制怎么开启)

    iphonex切换控制怎么用(iphonex切换控制怎么开启)

  • 手机wps怎么把表格加宽(手机wps怎么把表格的线去掉成空白)

    手机wps怎么把表格加宽(手机wps怎么把表格的线去掉成空白)

  • 电话转接怎么设置(400电话如何设置转接)

    电话转接怎么设置(400电话如何设置转接)

  • 苹果8边框掉漆怎么处理(苹果8边框掉漆怎么修复)

    苹果8边框掉漆怎么处理(苹果8边框掉漆怎么修复)

  • scratch趣味编程是什么(scratch趣味编程教案)

    scratch趣味编程是什么(scratch趣味编程教案)

  • 头条小视频怎么发朋友圈(头条小视频怎么保存到本地)

    头条小视频怎么发朋友圈(头条小视频怎么保存到本地)

  • 浏览器防火墙怎么设置(浏览器防火墙怎么关手机模式)

    浏览器防火墙怎么设置(浏览器防火墙怎么关手机模式)

  • 苹果怎么关后台(苹果怎么关闭运行的应用)

    苹果怎么关后台(苹果怎么关闭运行的应用)

  • 鼠标中间的滑轮用不了了(鼠标中间的滑轮按下去有什么用)

    鼠标中间的滑轮用不了了(鼠标中间的滑轮按下去有什么用)

  • 租赁企业可以开具电费发票吗
  • 银行贷款减值准备转回处理
  • 进口增值税和进项税
  • 租入房租装修费摊销
  • 买二手房为什么要交个人所得税
  • 小规模纳税人销售农产品税率是多少
  • 收到进项专用发票怎么做
  • 应收账款资产减值损失转回和核销的区别
  • 首次购买税控设备政策
  • 项目经费支出都包括什么
  • 车船税法律制度的规定什么是以每米为计税依据的
  • 税务局锁了开票系统票已领出还可以开出来吗
  • 金税盘里的增值税怎么算
  • 个人所得税承租承包经营所得
  • 金税盘抵扣增值税申报
  • 怎么分辨是否清真食品
  • 加工费月底需要全部结转吗
  • 小规模纳税人三个月做一次账
  • 利润表所得税费用为负数
  • 超过三年的坏帐损失税前扣除怎样规定?
  • 购买工程资质文件怎么写
  • windows 10输入法
  • 我开了一个物流公司,有人要开发票怎么办
  • 收到短期借款会计分录怎么做
  • fte文件怎么打开
  • 合并报表抵消分录未分配利润怎么算
  • 土增税清算扣除项目分摊公式
  • 购进商品发生溢余的核算
  • php如何调用接口
  • smiles查询
  • 食堂现金管理办法
  • node 卸载
  • win11大小核调度会优化吗
  • php怎么将数据库中的数据显示出来
  • 自动驾驶 模块
  • 什么是多模态研究
  • php.ini中date.timezone设置详解
  • 建筑工程收到材料发票怎么做账
  • 员工不小心重复报销了
  • 多计提费用可以不用以前年度损益调整吗
  • 免抵退税额怎么计算城建税
  • day10-Tomcat02
  • 政府专项基金是什么
  • 产品检测费计入成本吗
  • 投标报名费怎么做分录
  • 认缴怎么填
  • 无形资产是有在期资产吗
  • 完税证明可以做为证据使用吗
  • sqlserver设置简单模式
  • 个人银行账户进账多少
  • 社保里面的住房公积金买房可以便宜多少
  • 核定征收过了时间就不能申请了吧
  • 主营业务成本包括哪些
  • 普通发票可以扣除吗
  • 员工报销医药费怎么做会计分录
  • 固定资产贷款利息计算器
  • 代收会计分录
  • 单位代扣代缴个人所得税凭证
  • 建筑公司工程上班时间
  • mysql深入理解
  • window下mysql忘记密码
  • win10自带的音乐播放器groove如何设置
  • 如何更改win7
  • mac睡眠设置方法
  • centos6关闭图形界面
  • qclean.exe - qclean是什么进程 有什么用
  • Win10 TH2正式版偷偷恢复/篡改成对应的预装应用
  • 如何升级win
  • windows找不到硬盘驱动器
  • win7系统c盘占用空间大
  • wind移动版
  • linux命令行技巧
  • nodejs用法
  • css优化提高性能的方法有哪些
  • web标准有那几个方面
  • js 类继承
  • 基本农田建设的土地
  • 印花税计征周期
  • 个人独资企业如何避税
  • 银行最新税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设