vue路由传参的三种方式以及解决vue路由传参页面刷新参数丢失问题

最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决;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({
        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后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决;

其实解决页面刷新参数丢失问题的方案还有很多,比如把参数存在sessionStorange或者localStorange中都是可行的,不过我们既然用vue框架,就要用vue的方式来解决问题。这里只是想告诉大家,问题的解决方案可以多种多样,要学会用多种方式或者说多种方案来解决一个问题,不要有太多的局限性!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • SPA单页应用 传统的项目大多使用多页面结构,需要切换内容的时候我们往往会进行单个html文件的跳转,这个时候受网...
    视觉派Pie阅读 11,933评论 1 55
  • 路由基础知识 router和route的区别 route,是一个路由。 routes,是一组路由。 router,...
    lesdom阅读 1,661评论 5 13
  • 目录 - 1.vue-router响应 路由参数 的变化 - 2.vue-router如何定义嵌套路由? - 3....
    我跟你蒋阅读 5,678评论 0 14
  • 端午,早起登高,到魁星楼隧道上方 天旱,艾也长得矮瘦,必须节水节水节水!!! 忙碌的 端午节,为每年农历五月初五。...
    苏心2017阅读 246评论 0 0
  • 往事一幕幕重演,现在的你,还会犯以前一样的错误,还会做傻事吗?你还有半年的时间弥补自己的过失,你需要静下心来去思考...
    烧火_丫头阅读 132评论 0 0