vue路由传参方法
在编写vue项目时,时常会使用路由在不同页面中传递参数,常见使用方式如下:
this.$router.push({
path: "/test",
query: {
a: 1,
b: 2
}
})
这样我们就传递了两个参数,在 /test 页面 就可以接收这两个参数
let a = this.$route.query.a;
let b = this.$route.query.b;
可以看到浏览器进行了url参数拼接传参,有点像get请求的意思
如果不想显示参数拼接在url中,可以使用parmars传参,同时path失效,需要用name指定路由,前提vueRouter中有name对应的路由,才能匹配对应的路径
this.$router.push({
name: "test",
params: {
a: 1,
b: 2
}
})
接收参数方式 与query方式类似
let a = this.$route.parmars.a;
let b = this.$route.parmars.b;
看起来有点像post请求
以上看起来一切正常,但是一旦传递的参数中包含对象之后,问题就出现了
原因分析:
参数传递变为了[object object] ,这个我们非常熟悉,是对象被强制转化为字符串的结果
恍然大悟!原来vue路由传值会把参数都转换为字符串进行拼接,相当于String(参数)
解决方案:
解决方案很简单,就是使用JSON
传递参数时将参数转化为JSON字符串
this.$router.push({
path: "/test",
query: {
a: JSON.stringify({test : 'test}),
b: 2
}
})
接收时再转化为对象
let a = JSON.parse(this.$route.query.a);
let b = this.$routr.query.b;
完美解决