Vue中关于路由传参query和params的区别
Posted ylyw
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue中关于路由传参query和params的区别相关的知识,希望对你有一定的参考价值。
路由配置:{path:‘/login‘,name:‘Login‘,component:Login},
1.页面携带query参数跳转(path,name指定跳转到Login时都可以携带query参数) this.$router.push({ path:‘/login‘,name:‘Login‘, query: { id: this.id } ) query相当与发送了一次get请求,请求参数会显示在浏览器地址栏中
2.页面携带params参数跳转(携带params参数跳转时只能使用name指定)
this.$router.push({ name:‘Login‘, params: { id: this.id } )
params相当与发送了一次post请求,请求参数则不会显示,并且刷新页面之后参数会消失 当路由配置更改为
路由配置:{path:‘/login/:id‘,name:‘Login‘,component:Login} 并且再次发送请求,请求数据不会随着页面的刷新而消失 获取请求参数 this.$route.params.id this.$route.query.id
注:
router是VueRouter的一个对象,通过Vue.use(VueRouter)和VueRouter构造函数得到一个router的实例对象,这个对象中是一个全局的对象,他包含了所有的路由包含了许多关键的对象和属性。
$router.push({path:‘login‘});本质是向history栈中添加一个路由,在我们看来是 切换路由,但本质是在添加一个history记录;
而route是一个跳转的路由对象,每一个路由都会有一个route对象,是一个局部的对象,可以获取对应的name,path,params,query等
以上是关于Vue中关于路由传参query和params的区别的主要内容,如果未能解决你的问题,请参考以下文章