Vue路由传参两种方式

在vue-router路由中,传参方式一般分两种:


利用$route.query对象的Get方式传参,与http的get方式一样,会将参数暴露到地址栏,使用方式如下:

路由请求发起(编程式导航):

this.$router.push({path:'/selectById', query: {id: this.id}});

参数接收:

{{this.$route.query.searchBody}}

另一种是利用$route.params对象的Post方式传参,该方式具有一定限制,必须通过路径传参方式。

路由配置(根组件的路由配置js,若是vue-cli构建则为src/router/index.js):

import Vue from 'vue'
import Router from 'vue-router'
import User from '@/components/User'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      redirect: 'index'
    },
    {
      path: '/selectById/:id',
      component: User
    }
  ]
})

路由请求发起:

this.$router.push({path:'/selectById', params: {id: this.id}});

参数接收:

{{this.$route.params.searchBody}}

以上是常用的两种router传参方式,特别需要注意如果params不通过路径地址传参的话是取不到值的。

Vue路由传参两种方式。第一种是使用params传参。在路由配置中,可以在path中添加对应的参数,例如`/:param`。在跳转页面时,可以使用`this.$router.push({name: 'test', params: {name: 'tom'}})`来传递参数。在接收参数的页面中,可以使用`this.$route.params.name`来获取传递的参数。这种方式的缺点是,当页面刷新后,传递的参数会变成undefined。\[2\] 第二种方式是使用query传参。在跳转页面时,可以使用`this.$router.push({path: '/test', query: {name: 'tom'}})`来传递参数。在接收参数的页面中,可以使用`this.$route.query.name`来获取传递的参数。这种方式的优点是,即使页面刷新,传递的参数也不会丢失。\[3\] #### 引用[.reference_title] - *1* [Vue路由传参两种方式](https://blog.csdn.net/weixin_41080999/article/details/80379441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [VUE路由传参两种方式](https://blog.csdn.net/weixin_42250577/article/details/115296970)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值