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等

猜你喜欢

转载自www.cnblogs.com/shuaigebie/p/12717238.html
今日推荐