vue 页面跳转传参

两个页面之间的跳转如果需要传参(例如需要传递当前的id),js里写 window.location.href="xxxxx?id=xx 就可以了;
但是vue不一样 需要操作的是路由,需要用到 VueRouter
使用之前首先要了解 $router$route

$router是一个VueRouter的实例 可以导航到不同的路由里,如下

// 字符串
this.$router.push('/home')

// 对象
this.$router.push({ path: '/home' })

// 命名的路由
this.$router.push({ name: 'user', params: { userId: '123' }})

// 带查询参数,变成 /register?plan=private
this.$router.push({ path: '/register', query: { plan: 'private' }})

$route$router跳转到的当前一个对象,里面包含当前我们可以获取的path、query、name 、params等属性,如下
在里插入图片描述

因此VueRouter 两种传参方法,

1.第一种传参 name 与 params的结合使用 ,

const id = '123'  // 假设id为123
// 利用name和params传参
this.$router.push({ name: 'home', params: { id }}) // -> /home/123
// 也可以直接传参
this,$router.push({ path: `/home/${id}` }) // -> /home/123

// 这里的 params 不生效,因为path要和query搭配
this.$router.push({ path: '/home', params: { id }}) // -> /home

如果传参时设置name属性,则需要在定义路由规则对象时也要设置name,并且path的值需要有/:id,如果没有/:id,则params传值一刷新页面就没了

// 如果传参设置name属性,则需要在定义路由对象规则时也要设置name
{ 
	path: '/home/:id',
  	name: 'home',
 	component: Home 
 }

2.第二种传参 path 与 query结合使用 ,

const id = '123'  // 假设id为123
// 带查询参数,变成 /home?id=123
this.$router.push({ path: 'home', query: { id }})

 

3.跳转后的页面取值用法类似,分别是this.$route.params.idthis.$route.query.id就可以得到id值。

总结:query类似于get传参,params则类似于post,即前者在浏览器地址栏中显示参数,后者则不显示 ,params传参一刷新就没了(如果传的参数在刷新后依旧存在,需要设置/:id),query传参刷新参数还存在

posted @   CNBlackICE  阅读(1533)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示