首先简单来说明一下router和router和router和route的区别
$router : 是路由操作对象,只写对象
$route : 路由信息对象,只读对象
1·query传递参数
//query传参,使用path跳转
this.$router.push({
path:'second',
query: {
queryId:'20180822',
queryName: 'query'
}
})
//query传参接收
this.queryName = this.$route.query.queryName;
this.queryId = this.$route.query.queryId;

2·params传递参数
注:使用params传参只能使用name进行引入
使用params传参
//params传参 使用name
this.$router.push({
name:'second',
params: {
id:'20180822',
name: 'query'
}
})
//params接收参数
this.id = this.$route.params.id ;
this.name = this.$route.params.name ;
总结
1.传参可以使用params和query两种方式。
使用params传参只能用name来引入路由,即push里面只能是name:’xxxx’,不能是path:’/xxx’,因为params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined!!!。
2.使用query传参使用path来引入路由。
params是路由的一部分,必须要在路由后面添加参数名。query是拼接在url后面的参数,没有也没关系。
3.二者还有点区别,直白的来说query相当于get请求,页面跳转的时候,可以在地址栏看到请求参数,而params相当于post请求,参数不会再地址栏中显示。
本文详细介绍了Vue Router中query和params两种参数传递方式的使用和区别。query参数通过URL路径后面的问号显示,类似GET请求,而params参数不会显示在URL上,类似于POST请求。在使用params传递时,必须通过name定义路由,而query则可以使用path。总结了params和query的适用场景及优缺点。
2610

被折叠的 条评论
为什么被折叠?



