Vue 路由传参及接收参数

方法一:params 传参

this.$router.push({
    name:"admin",
    //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取)
    params:{id:item.id}
})    
 
//这个组件对应的路由配置
{
  //组件路径
  path: '/admin',
  //组件别名
  name: 'admin',
  //组件名
  component: Admin,
}
  • 通过 params 传递参数,如果我们想获取 id 的参数值,可以通过 this.$route.params.id

注意:获取参数的时候是 route,跳转和传参的时候是router

方法二:路由属性配置传参

this.$router.push({
    path:"/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 传参,如果我们想获取 id 的参数值,可以通过 this.$route.query.id。
  • 用 query 传参可以解决页面刷新参数消失问题,这种方式可以理解为是 ajax中的 get 方法,参数是直接在 url 后面添加的,参数是可见的。
  • 如果不想让参数可见,又要解决刷新页面参数消失问题,只好用下面的方法。

方法四:localStorage

// 存数据
localStorage.setItem("numbers", JSON.stringify(this.numbers));

// 取数据
this.numbers = JSON.parse(localStorage.getItem("numbers"));

注意使用 localStorage 时,如果变量名起的过于普通可能容易被其它页面存的数据覆盖

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容