路由传参的方法总结

目录

1.params传参(显示参数)

 声明式

编程式

2.params传参(不显示参数)

 声明式

编程式

 3.query传参(显示参数)

声明式

编程式


路由传参的使用场景一般都是应用在父路由跳转到子路由时,携带参数跳转。

传参方式可划分为 params 传参和 query 传参,而 params 传参又可分为在 url 中显示参数和不显示参数两种方式,这就是vue路由传参的三种方式。

1.params传参(显示参数)

可分为声明式和编程式两种方式。

 声明式

该方式是通过 router-link 组件的 to 属性实现,该方法的参数可以是一个字符串路径,或者一个描述地址的对象。使用该方式传值的时候,需要子路由提前配置好参数,例如:

//子路由配置
{
  path: '/child/:id',
  component: Child
}
//父路由组件
<router-link :to="/child/123">
    进入Child路由
</router-link>
编程式

this.$router.push()使用该方式传值的时候,同样需要子路由提前配置好参数,例如:

//子路由配置
{
  path: '/child/:id',
  component: Child
}
//父路由编程式传参(一般通过事件触发)
this.$router.push({
    path:'/child/${id}',
})

在子路由中可以通过 this.$route.params.id 来获取传递的参数值。

2.params传参(不显示参数)

分为声明式和编程式两种方式,与方式一不同的是,这里是通过路由的别名 name 进行传值。

 声明式

也是通过router-link的to属性实现。

<router-link :to="{name:'Child', params:{id:123}}">
    进入Child路由 
</router-link>
编程式

使用该方式传值的时候,同样需要子路由提前配置好参数,不过不能再使用 :/id 来传递参数了,因为父路由中,已经使用 params 来携带参数了,例如:

//子路由配置
{
  path: '/child,
  name: 'Child',
  component: Child
}
//父路由编程式传参(一般通过事件触发)
this.$router.push({
    name:'Child',
    params:{
    	id:123
    }
})

在子路由中可以通过 this.$route.params.id 来获取传递的参数值。

注意:上述这种利用 params 不显示 url传参的方式在刷新页面的时候,传递的参数会丢失。

 3.query传参(显示参数)

声明式

该方式也是通过 router-link 组件的 to 属性实现,不过使用该方式传值的时候,需要子路由提前配置好路由别名(name 属性),例如:

//子路由配置
{
  path: '/child,
  name: 'Child',
  component: Child
}
//父路由组件
<router-link :to="{name:'Child',query:{id:123}}">进入Child路由</router-link>
编程式

用该方式传值的时候,同样需要子路由提前配置好路由别名(name 属性),例如:

//子路由配置
{
  path: '/child,
  name: 'Child',
  component: Child
}
//父路由编程式传参(一般通过事件触发)
this.$router.push({
    name:'Child',
    query:{
    	id:123
    }
})

在子路由中可以通过this.$route.query.id来获取传递的参数值

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在uniapp中,可以使用多种方式进行路由传参。其中一种常用的方式是通过参数传递。通过uni.navigateTo或uni.redirectTo方法进行页面跳转时,可以在url路径后面拼接参数,例如:uni.navigateTo({ url: '/pages/B/B?id=123&name=uniapp' })。在目标页面的onLoad方法中,可以通过this.$route.query来获取传递的参数。这种方式适用于简单的参数传递场景。\[1\] 除了参数传递,uniapp还提供了其他方式来实现路由传递数据的功能,包括事件总线和vuex状态管理。事件总线是一种在不同页面之间传递数据的机制,可以通过uni.$emit方法发送事件,在目标页面通过uni.$on方法监听事件并获取数据。而vuex是一种全局状态管理工具,可以在不同页面之间共享数据。通过在vuex中定义和修改数据,可以实现跨页面的数据传递和共享。这两种方式适用于复杂的数据传递场景。\[2\] 总结起来,uniapp中的路由传参可以通过参数传递、事件总线和vuex状态管理等方式实现,具体选择哪种方式取决于实际需求和场景。 #### 引用[.reference_title] - *1* *2* [Uniapp路由传递数据](https://blog.csdn.net/m0_71469120/article/details/130363980)[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] - *3* [uni-app路由跳转以及页面传参方法](https://blog.csdn.net/m0_46156566/article/details/105517136)[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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值