vue中this.$router.push()路由传值和获取值的方法
1、路由传值 this.$router.push()(1) 想要导航到不同的URL,使用router.push()方法,这个方法会向history栈添加一个新纪录,所以,当用户点击浏览器后退按钮时,会回到之前的URL(2)当使用 <router-link:to="…" /> 时,内部调用的也是router.push()方法,所以使用<router-link /> 等同于调用
·
1、路由传值 this.$router.push()
(1) 想要导航到不同的URL,使用router.push()方法,这个方法会向history栈添加一个新纪录,所以,当用户点击浏览器后退按钮时,会回到之前的URL
(2)当使用 < router-link :to="…" /> 时,内部调用的也是router.push()方法,所以使用 < router-link /> 等同于调用 router.push() 方法
- 声明式:< router-link :to="…" />
- 编程式:router.push(…)
- 该方法的传入的参数可以是字符串或者对象
// 字符串
router.push('home')
// 对象
this.$router.push({path: '/login?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.$http.post('v1/user/select-stage', {stage: stage})
.then(({data: {code, content}}) => {
if (code === 0) {
// 对象
this.$router.push({path: '/home'});
}else if(code === 10){
// 带查询参数,变成/login?stage=stage
this.$router.push({path: '/login', query:{stage: stage}});
}
});
// 设计查询参数对象
let queryData = {};
if (this.$route.query.stage) {
queryData.stage = this.$route.query.stage;
}
if (this.$route.query.url) {
queryData.url = this.$route.query.url;
}
this.$router.push({path: '/my/profile', query: queryData});
2、获取参数的两种常用方法:params和query
(1)this.$route.params获取值:
因为动态路由也是传递params的,所以在 this.$router.push() 方法中 path不能和params一起使用,否则params将无效。需要用name来指定页面。
传值
this.$router.push({name:"menuLink",params:{alert:"页面跳转成功"}})
取值
<p>{{this.$route.params.alert}}</p>
(2)this.$route.query 获取值:
传值
this.$router.push({path:"/menLink",query:{alert:"页面跳转成功"}})
取值
<p>{{this.$route.query.alert}}</p>
更多推荐
已为社区贡献19条内容
所有评论(0)