react路有传参

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

路由页面:<Route path='/demo/:id' component={Demo}></Route>  //注意要配置 /:id
路由跳转并传递参数:
    链接方式:<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

1、params传参(多个动态参数)

state={
    id:88,
    name:'Jack',
}
路由页面:<Route path='/demo/:id/:name' component={Demo}></Route>  
路由跳转并传递参数:
    链接方式:<Link to={{pathname:`/demo/${this.state.id}/${this.state.name}`}}>XX</Link>

    js方式:this.props.history.push({pathname:`/demo/${this.state.id}/${this.state.name}`})
获取参数:this.props.match.params     //结果 {id: "88", name: "Jack"}

2、query传参(刷新页面后参数消失)

路由页面:<Route path='/demo' component={Demo}></Route>  //无需配置
路由跳转并传递参数:
    链接方式:<Link to={{pathname:'/demo',query:{id:22,name:'dahuang'}}}>XX</Link>
    js方式:this.props.history.push({pathname:'/demo',query:{id:22,name:'dahuang'}})
获取参数: this.props.location.query.name

3、state传参( 刷新页面后参数不消失,state传的参数是加密的,比query传参好用)

注:state 传参的方式只支持Browserrouter路由,不支持hashrouter

路由页面:<Route path='/demo' component={Demo}></Route>  //无需配置
路由跳转并传递参数:
    链接方式: <Link to={{pathname:'/demo',state:{id:12,name:'dahuang'}}}>XX</Link> 
    js方式:this.props.history.push({pathname:'/demo',state:{id:12,name:'dahuang'}})
获取参数: this.props.location.state.name
React中进行页面跳转并传递参数,可借助`react-router-dom`库实现,以下是几种常见方法: - **使用`<Link>`组件传参**:通过`<Link>`组件可实现页面跳转并传递参数。示例代码如下: ```jsx // 跳转到详情页并传递参数 <Link to={{ pathname: '/detail', state: { id: 123 } }}>详情页</Link> // 由配置 <Route path="/detail/:id" component={Detail} /> // 目标组件中获取参数 class Detail extends React.Component { render() { const { id } = this.props.match.params; const { id } = this.props.location.state; return ( <div> <h1>详情页</h1> <p>ID: {id}</p> </div> ); } } ``` 在上述代码里,`<Link>`组件的`to`属性为一个对象,`pathname`指定跳转径,`state`用于传递参数。在目标组件里,可通过`this.props.match.params`和`this.props.location.state`获取参数 [^2]。 - **使用`useLocation()`钩子获取参数**:`useLocation()`是`react-router-dom`提供的钩子,用于获取当前由的位置对象,`location.state`为从其他页面传递过来的状态数据。当使用`navigate`或`<Link>`组件导航时,可传递`state`对象来传递参数 [^3]。 - **使用`search`传递参数**:使用`search`传递参数,刷新页面后参数依然存在。示例代码如下: ```jsx // 接收参数 export default (props) => { const history = useHistory(); useEffect(() => { //query也可以改成state console.log(history.location.query); // {dictCode:765} // 注意!当刷新页面获取的参数就为空了。 }, []); } ``` 在上述代码中,可通过`history.location.query`获取传递的参数 [^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值