路由传参方式

本文介绍了React.js中四种路由传参方式:params、search、query和state。重点讲解了params方式,包括参数不丢失的情况,多个动态参数的传递,以及参数非必传的处理。同时提到search方式使用qs库转化URL参数,query传参刷新后参数消失,以及state模式下参数刷新后会丢失的特点。
摘要由CSDN通过智能技术生成

路由传参方式

1.params方式

参数不丢失但是需要一个个手动定义

this.props.history.push({pathname:`/detail/${id}`})

获取参数

this.props.match.params.id

路由文件中的配置

<Route path="/detail/:id/:orderId?" component={Detail} />

1.1 params传参(刷新页面后参数不消失,参数会在地址栏显示)

路由页面:

注意要配置 /:id

<Route path='/demo/:id' component={
   Demo}></Route>  
路由跳转并传递参数:
链接方式:
		<Link to={'/demo/'+'6'}>XX</Link>
或:<Link to={
  {pathname:'/demo/'+'6'}}>XX</Link>

js方式:
	 this.props.history.push('/demo/'+'6')  
或:this.props.history.push({pathname:'/demo/'+'6'})
获取参数:
this.props.match.params.id    //注意这里是match而非history
或
import {useParams} from 'react-router-dom';
const params = useParams();
console.log(params); //{id:6}

1.2 params传参(刷新页面后参数不消失,多个动态参数)

路由页面:

注意要配置 /:type/:id 这两个参数是必传

<Route path='/detail/:type/:id' component={
   Demo}></Route>  
路由跳转并传递参数:

此时不传type和id跳转过去页面不出来,带参数的可以正常显示

链接方式:
<Link to="/detail">新增</Link> 
<Link to={`/detail/1/${record.id}`}>查看</Link>
<Link to={`/detail/2/${record.id}`}>编辑</Link>
或
<Link to={
  {pathname:`/detail/1/${record.id}`}}>查看</Link>

js方式:this.props.history.push({pathname:`/detail/1/${record.id}`})
获取参数:
this.props.match.p
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值