当前位置:   article > 正文

vue中用this.router.push()路由params传参遇到的页面刷新数据丢失问题_router.push params

router.push params

最近项目中涉及到跨页面传参数和后台进行数据交互以及用this.router.push()路由params传参遇到的页面刷新数据丢失问题,看到需求之后第一反应就是用路由传参来解决,Vue中提供了三种路由传参方式:
第一种:params传参

this.$router.push({
        name:"admin",
    //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或		者Vue实例上直接取)
        params:{id:item.id}
})       

//这个组件对应的路由配置
{
  //组件路径
    path: '/admin',
  //组件别名
    name: 'admin',
  //组件名
    component: Admin,
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

通过params传递参数,如果我们想获取id的 参数值,我们可以通过this.$ route.params.id这种方式来打印出来就可以得到了;(注意:获取参数的时候是$ route,跳转和传参的时候是$ router)

第二种:路由属性配置值传参

this.$router.push({
        name:"/admin/${item.id}",
})       

//这个组件对应的路由配置
{
  //组件路径
    path: '/admin:id',
  //组件别名
    name: 'admin',
  //组件名
    component: Admin,
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

通过路由属性配置传参我们可以用this. r o u t e . p a r a m s . i d 来 获 取 到 i d 的 值 , 注 意 t h i s . route.params.id来获取到id的值,注意this. route.params.ididthis.router.push方法里面路径带的是值,路由配置项那里带的是变量名(属性名)来实现的对应;

以上两种传参方式基本上可以理解为ajax中的post请求方式,参数都是不可见的,但是上面两种方法都有一个弊端,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢?

方法三:query传参

this.$router.push({
        path:"/admin",
     query:{id:item.id}
})       

//这个组件对应的路由配置
{
  //组件路径
    path: '/admin',
  //组件别名
    name: 'admin',
  //组件名
    component: Admin,
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

通过query传参可以解决刷新页面数据丢失的问题
这种方式可以理解为是ajax中的get方法,参数是直接在url后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决
其实还可以通过把参数存在sessionStorage和localStorage中,来解决这个问题

本文中参考了https://www.cnblogs.com/dengyao-blogs/p/11399676.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/285205
推荐阅读
相关标签
  

闽ICP备14008679号