在 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 并不要求完全匹配。

相关推荐
Thanks_ks几秒前
探索现代 Web 开发:从 HTML5 到 Vue.js 的全栈之旅
javascript·vue.js·css3·html5·前端开发·web 开发·全栈实战
GIS之路4 分钟前
OpenLayers 获取地图状态
前端·javascript·html
FogLetter20 分钟前
深入理解Flex布局:grow、shrink和basis的计算艺术
前端·css
remember_me21 分钟前
前端打印实现-全网最简单实现方法
前端·javascript·react.js
前端小巷子23 分钟前
IndexedDB:浏览器端的强大数据库
前端·javascript·面试
Whbbit199924 分钟前
如何使用 Vue Router 的类型化路由
前端·vue.js
JYeontu28 分钟前
浏览器书签还能一键下载B站视频封面?
前端·javascript
陈随易29 分钟前
Bun v1.2.16发布,内存优化,兼容提升,体验增强
前端·后端·程序员
聪明的水跃鱼30 分钟前
Nextjs15 基础配置使用
前端·next.js
happyCoder31 分钟前
如何判断用户设备-window.screen.width方式
前端