React 的路由传参

简介: React 的路由传参

1.路由传参

1.动态路由传参

使用prop进行接收 props.match.params.参数名

2.query传参

this.props.history.push({
pathname: ‘路由’,
query:{参数名:参数值}
})
接收:
this.props.location.query.参数名

3.state传参

this.props.history.push({
pathname: ‘路由’,
state:{参数名:参数值}
})
接收:
this.props.location.state.参数名

2.路由拦截

正常我们创建路由都是

<Route path="" component={组件}></Route>

我们也可以写成

<Route path="" render={(props) => {
  在这里我们可以进行路由拦截,处理一些东西,判断要显示那个组件
  由于我们在函数中组件已经实例化,我们在其他组件中通过props进行路由跳转会发生报错,拿不到props,所以我们需要在render函数中将
  props传入,将props传入组件中,例如:<Clird {...props}/>,这样就可以通过props进行跳转
}}></Route>

3.路由模式

HashRouter这个是hash模式,带#号的,如果不想使用#,我们可以将HashRouter换为BrowserRouter就可以了

4.withRouter

当子组件中无法拿到props时,我们通常使用withRouter()方法进行包裹,将返回值赋予一个新变量,这个变量就是我们包裹完的新组件将这个组件替换原来的组件就可以就

const 新组件名 = withRouter(组件名)
相关文章
|
6月前
|
存储 前端开发 JavaScript
【第34期】一文学会React组件传值
【第34期】一文学会React组件传值
75 0
|
2月前
|
JavaScript 网络架构
|
JavaScript 前端开发
react-6-路由-2-嵌套路由-404
react-6-路由-2-嵌套路由-404
69 0
|
6月前
|
JavaScript
Vue路由传参的几种方式详解
vue-router传递参数分为两大类: >编程式的导航 router.push 声明式的导航 <router-link>
|
前端开发 Java
react 路由传参总结
react 路由传参总结
56 0
|
JavaScript 网络架构
react-6-路由-3-路由传值
react-6-路由-3-路由传值
44 0
|
前端开发
React-Router-嵌套路由
React-Router-嵌套路由
87 0
|
前端开发 网络架构
React 的路由传参
React 的路由传参
|
前端开发
react路由传参的三种方式(易理解)
react路由传参的三种方式(易理解)
|
前端开发
react-router-dom v6 navigate路由传参
react-router-dom v6 navigate路由传参
91 0