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

路由器
路由器
3580
文章
0
评论
2023-04-2010:14:28 常见问题阅读 91

  最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决;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的方式来解决问题。这里只是想告诉大家,问题的解决方案可以多种多样,要学会用多种方式或者说多种方案来解决一个问题,不要有太多的局限性!

文章转载自微信公众号有梦想的咸鱼前端

点击展开全文

相关推荐

  • 千古难题:路由器到底用不用定期关闭?
  • 网络延迟高怎么办?优化路由器设置解决延时问题
  • 自救秘籍丨一分钟故障排查,看指示灯为路由把脉
  • 牛人总结!机顶盒、路由器常见问题及处理方法
  • 路由故障:IP路由故障关于BGP的疑问解答
  • WiFi慢成dog?不是网的问题,是你路由器设错了!
  • 千古难题:路由器到底需不需要关闭?
  • 不容忽视的健康问题!一组漫画揭示无线路由器暗藏的辐射危机
  • 路由器桥接故障导致用户看电视卡顿
  • 一台家用无线路由器最多能连接多少个无线设备?
  • 思科路由器网络诊断与故障排除
  • 疑因路由器所接排插故障引发火灾 楼上灭"火焰山" 楼下变"水帘洞"
  • 路由器五个常见故障解决方法
  • H3C | SR6616策略路由+单臂+nat组网不通问题经验案例
  • 路由器设置:无线路由设置问题(以磊科NW717为例)
  • 部分TPLINK 886N路由器无法拨号上线问题