vue项目——路由传参与router-link传参 多种方式详解

最近项目中涉及到跨页面传参数和后台进行数据交互,经过多方搜索参考决定用路由传参来解决。

Vue中给我们提供了三种路由传参方式,:

  方法一:params传参(只能由name引入)

1.params传参、使用name:
this.$router.push({
        name:"Check", 
        params:{id:item.id, num:item.num}
})    


2.params接收参数:
this.id = this.$route.params.id
this.name = this.$route.params.num
   

3.router.js中的配置:
{
    path: '/check',
    name: 'Check',
    component: Check,
}

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

 

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

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

//这个组件对应的路由配置
{
    path: '/check:id',
    name: 'Check',
    component: Check,
}

  通过路由属性配置传参我们可以用this.$route.params.id来获取到id的值,注意this.$router.push方法里面路径带的是值,路由配置项那里带的是变量名(属性名)来实现的对应;

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

 

  方法三:query传参

1.query传参、使用path:
this.$router.push({
        path:"Check", 
        params:{id:item.id, num:item.num}
})    


2.query接收参数:
this.id = this.$route.query.id
this.name = this.$route.query.num
   

3.router.js中的配置:
{
    path: '/check',
    name: 'Check',
    component: Check,
}

  第三种方式是用query来传参,这种方式是可以解决页面刷新参数消失问题的,这种方式可以理解为是ajax中的get方法,参数是直接在url后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决;

  

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

项目过程中使用及参考链接:

https://www.cnblogs.com/dengyao-blogs/p/11399676.html

https://blog.csdn.net/tianxintiandisheng/article/details/82774644

https://blog.csdn.net/muzidigbig/article/details/83684391