Vue路由传参三种方式
par am s传参 路由属性配置传参 query传参
一、params传参
this. $router .push({ name:"admin", //这里的params是一个对象,id是属性名, IT em.id是值(可以从当前组件 或者 vue实例 上直接取) params:{id:item.id} }) //这个组件对应的路由配置 { //组件路径 path: '/admin', //组件别名 name: 'admin', //组件名 component : Admin, }
通过params传递参数,如果我们想获取 id 的参数值,可以通过 this.$route.params.id 这种方式来打印出来就可以得到了;
注意 :获取参数的时候是 $route,跳转和传参的时候是 $router
二、路由属性配置传参:
this.$router.push({ name:"/admin/${item.id}", }) //这个组件对应的路由配置 { //组件路径 path: '/admin:id', //组件别名 name: 'admin', //组件名 component: Admin, }
通过路由属性配置传参我们可以用 this.$route.params.id 来获取到 id 的值,
注意 this. $router.push 方法里面路径带的是值,路由配置项那里带的是 变量名 (属性名)来实现的对应;
以上两种传参方式基本上可以理解为 ajax 中的 post 请求方式, 参数都是不可见的 ,但是上面两种方法都有一个弊端,就是当 页面刷新了是获取不到参数值 的,那么有没有一种方法是页面刷新之后参数依然存在呢?
三、query传参
this.$router.push({ name:"/admin", query:{id:item.id} }) //这个组件对应的路由配置 { //组件路径 path: '/admin', //组件别名 name: 'admin', //组件名 component: Admin, }
第三种方式是用 query 来传参,这种方式是可以解决页面刷新参数 消失 问题的,这种方式可以理解为是 ajax 中的 get 方法,参数是直接在 url 后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用此方法来解决;
区别
(1)params传参
只能用 name,不能用 path。 地址栏不显示参数名称 id,但是有参数的值。(2)query传参
name 和 path 都能用。用 path 的时候,提供的 path 值必须是相对于 根路径 的相对路径,而不是相对于父路由的相对路径,否则无法成功访问。 地址栏显示参数格式为?id=0&am p; code=1
特别注意
route与router的区别。route表示路由属性;router表示路由实例。
以上3种是路由传参的基本方式。除了以上 几种 还可以使用sessionStorage/localStorage/cookie进行存储也可以进行存储也可以,使用VUEX也行,具体因场景而异。
总结
到此这篇关于Vue路由传参的三种方式的 文章 就介绍到这了,更多相关Vue路由传参方式内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章: vue动态路由配置及路由传参的方式 vue路由跳转传参数的方法 3种vue路由传参的基本模式 vue路由传参三种基本方式详解 vue路由传参方式的方式总结及获取参数详解 详解Vue 路由组件传参的 8 种方式
总结
以上是 为你收集整理的 Vue路由传参的三种方式实例详解 全部内容,希望文章能够帮你解决 Vue路由传参的三种方式实例详解 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于Vue路由传参的三种方式实例详解的详细内容...