vue中this.$router.push()路由传值和获取的两种常见方法

本文详细介绍了在 Vue 中使用 this.$router.push() 进行路由传值的两种方法,包括通过字符串路径、命名路由和查询参数。同时,也阐述了如何在目标页面获取这些参数,分别通过 this.$route.params 和 this.$route.query。注意params和query的区别,params用于隐藏传参,query则会显示在URL中。
摘要由CSDN通过智能技术生成

vue中this.$router.push()路由传值和获取的两种常见方法

1、路由传值 this.$router.push()
(1) 想要导航到不同的URL,使用router.push()方法,这个方法会向history栈添加一个新纪录,所以,当用户点击浏览器后退按钮时,会回到之前的URL
(2)当点击 时,这个方法会在内部调用,即点击 等同于调用 router.push(…)
  a) 声明式:
  b) 编程式:router.push(…)
  c) 该方法的参数可以是一个字符串路径,或者一个描述地址的对象。

// 字符串
router.push(‘home’)

// 对象
this.KaTeX parse error: Expected '}', got 'EOF' at end of input: …n?url=' + this.route.path});

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

// 带查询参数,变成/backend/order?selected=2
this.$router.push({path: ‘/backend/order’, query: {selected: “2”}});

// 设置查询参数
this.KaTeX parse error: Expected '}', got 'EOF' at end of input: … this.router.push({path: ‘/home’});
}else if(code === 10){
// 带查询参数,变成/login?stage=stage
this.$router.push({path: ‘/login’, query:{stage: stage}});
}
});

// 设计查询参数对象
let queryData = {};
if (this.KaTeX parse error: Expected '}', got 'EOF' at end of input: …a.stage = this.route.query.stage;
}
if (this.KaTeX parse error: Expected '}', got 'EOF' at end of input: …ata.url = this.route.query.url;
}
this.$router.push({path: ‘/my/profile’, query: queryData});
在这里插入图片描述

2、获取参数的两种常用方法:params和query
(1)由于动态路由也是传递params的,所以在 this.$router.push() 方法中path不能和params一起使用,否则params将无效。需要用name来指定页面。
及通过路由配置的name属性访问
在这里插入图片描述
在这里插入图片描述

this. r o u t e r . p u s h ( n a m e : " m e n u L i n k " , p a r a m s : a l e r t : " 页 面 跳 转 成 功 " ) ( 2 ) 在 目 标 页 面 通 过 t h i s . router.push({name:"menuLink",params:{alert:"页面跳转成功"}}) (2)在目标页面通过this. router.push(name:"menuLink",params:alert:"")2this.route.params获取参数:

提示:{{this.$route.params.alert}}

(3)在目标页面通过this.$route.query 获取参数 //传值 this.$router.push({path:"/menLink",query:{alert:"页面跳转成功"}})

//用query获取值

提示:{{this.$route.query.alert}}

两种方式的区别是query传参的参数会带在url后边展示在地址栏,params传参的参数不会展示到地址栏。需要注意的是接收参数的时候是route而不是router。两种方式一一对应,名字不能混用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值