Vue-Router路由携带参数跳转3种方式大全,刷新页面参数不丢失,不显示到地址url中

47 篇文章 69 订阅

此博客将详细介绍Vue-router传参的方法大全,以及如何刷新页面参数不丢失且不拼接到url中。

Vue-Router携带参数跳转的3种方式

Vue-Router 提供了多种传参的方式,具体如下:

1. parmas路由路径传参

在定义路由时,可以在路由路径中添加参数占位符,例如:/user/:id

在路由路径中以 : 开头的是参数占位符,参数名称为 id。在匹配该路由时,例如访问 /user/1,会把参数 id 填入组件的 this.$route.params 对象中。

2. query查询参数传参

查询参数传参是在 URL 后面带上参数,例如:/user?id=1

在 Vue-Router 中访问查询参数可以通过 $route.query 来获取,例如:

const user_id = this.$route.query.id

3. Props 传参

在路由组件中可以通过 props 将参数传递给组件,需要在路由配置中设置 props 属性:

const router = new VueRouter({
  routes: [
    {
      path: '/user/:id',
      component: User,
      props: true
    }
  ]
})

在这种情况下,参数会被设置为组件的 props,例如访问 /user/1,会把参数 id 传递给组件 User 的 props 中,可以通过 this.id 访问到。

  1. 组件内部获取路由参数

在组件内部可以通过 this.$route.params 或者 this.$route.query 获取路由参数,在组件内部可以直接使用 $route 来访问组件的路由信息。

  1. 根据路由名称传参

通过路由名称来传递参数,需要在定义路由时设置 name 属性,例如:

const router = new VueRouter({
  routes: [
    {
      path: '/user/:id',
      name: 'user',
      component: User
    }
  ]
})

在此处定义了一个名为 user 的路由,然后可以在其它地方通过 name 来访问该路由,例如:

this.$router.push({
  name: 'user',
  params: {
    id: 1
  }
})

可以通过 this.$route.params 获取参数。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coderYYY

请简单粗暴地爱我,一元一元的赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值