在 React Router v5 中,写子路由,父级路由如果加了exact属性,就显示不了子组件

在 React Router v5 中,当你在父级路由上使用 exact 属性时,它意味着该路由只有在其 path 完全匹配当前 URL 时才会被激活。这意味着,如果父级路由精确匹配了,React Router 就不会继续向下查找子路由,因为 exact 限制了匹配范围。

例如,假设你有以下路由配置:

<Route exact path="/parent" component={ParentComponent}>
  <Route path="/parent/child" component={ChildComponent} />
</Route>

在这个例子中,如果你访问 /parent,因为父级路由设置了 exact,它将匹配并仅渲染 ParentComponent。即使存在一个子路由 /parent/child,由于父级路由已经精确匹配,React Router 不会继续尝试匹配子路由,因此 ChildComponent 不会被渲染。

如果你希望同时能够访问父级和子级组件,应该移除父级路由上的 exact 属性,让路由系统有机会继续匹配子路由:

<Route path="/parent">
  <Route path="/parent/child" component={ChildComponent} />
</Route>

这样配置后,访问 /parent 会渲染 ParentComponent,而访问 /parent/child 则会同时渲染 ParentComponent(作为容器)和 ChildComponent。如果没有其他路由与 /parent 完全匹配,就不需要 exact,因为默认情况下 Route 并不要求完全匹配。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React Router v5 ,获取路由参数的方式会略有不同。你可以通过以下步骤在类组件获取路由参数: 1. 首先,确保你已经正确配置了 React Router,并在应用的根组件包裹了 `<Router>` 组件。这样才能使路由参数在整个应用可用。 2. 在类组件,你可以通过 `this.props.match.params` 来访问路由参数。`match` 对象的 `params` 属性是一个包含路由参数的对象。 下面是一个示例: ```jsx import React from 'react'; import { BrowserRouter as Router, Route, Link } from 'react-router-dom'; class MyComponent extends React.Component { render() { const { id } = this.props.match.params; // 获取名为 "id" 的路由参数 return ( <div> <h1>My Component</h1> <p>路由参数: {id}</p> </div> ); } } class App extends React.Component { render() { return ( <Router> <div> <h1>App</h1> <ul> <li> <Link to="/component/1">组件 1</Link> </li> <li> <Link to="/component/2">组件 2</Link> </li> </ul> <Route path="/component/:id" component={MyComponent} /> </div> </Router> ); } } export default App; ``` 在上面的示例,我们定义了一个 `MyComponent` 类组件,它通过 `this.props.match.params` 获取名为 "id" 的路由参数。然后,我们在 `App` 组件使用 `<Route>` 组件来将 `MyComponent` 组件与 `/component/:id` 路径匹配。 通过这种方式,当访问 `/component/1` 或 `/component/2` 路径时,`MyComponent` 组件会被渲染,并可以获取到对应的路由参数。 请注意,上述示例是使用了 React Router v5 的方式获取路由参数。如果你正在使用 React Router v6,请参考之前我提供的关于 v6 的回答。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值