react-router-dom V6 的嵌套路由 使用 Route 嵌套实现
时间: 2024-05-05 21:19:34 浏览: 310
React-Router-Dom V6 中嵌套路由使用 Route 嵌套实现的示例如下:
```javascript
import { Route, Routes } from 'react-router-dom';
const App = () => (
<Routes>
<Route exact path="/" element={<Home />} />
<Route path="/about" element={<About />}>
<Route path="/contact" element={<Contact />} />
<Route path="/team" element={<Team />} />
</Route>
<Route path="/services" element={<Services />} />
</Routes>
);
```
在上述示例中,嵌套路由的实现通过 Route 组件的嵌套来实现。例如,/about 路径下的 Contact 和 Team 组件只有在访问 /about/contact 和 /about/team 路径时才会显示。这样做可以使路由的组织更加清晰,更易于维护。
相关问题
react-router-dom v6,嵌套路由
在 React Router v6 中,请使用 `<Routes>` 和 `<Route>` 组件来创建嵌套路由。以下是一个示例:
```jsx
import { BrowserRouter as Router, Routes, Route } from 'react-router-dom';
function App() {
return (
<Router>
<Routes>
<Route path="/" element={<Home />} />
<Route path="/about" element={<About />} />
<Route path="/users" element={<Users />}>
<Route path="/" element={<UserList />} />
<Route path=":id" element={<UserDetails />} />
</Route>
</Routes>
</Router>
);
}
function Home() {
return <h1>Home</h1>;
}
function About() {
return <h1>About</h1>;
}
function Users() {
return (
<div>
<h1>Users</h1>
<Outlet />
</div>
);
}
function UserList() {
return <h2>User List</h2>;
}
function UserDetails() {
return <h2>User Details</h2>;
}
```
在上面的示例中,`<Routes>` 组件是路由的根,`<Route>` 组件用于定义路由的路径和对应的组件。嵌套路由可以在父级 `<Route>` 组件内部使用更多的 `<Route>` 组件来定义。
在 `/users` 路径下,`<Users>` 组件使用了 `<Outlet>` 组件,它用于渲染嵌套的子路由。`<UserList>` 和 `<UserDetails>` 组件分别是 `/users` 和 `/users/:id` 路径的子组件。
这样,当访问 `/users` 路径时,会渲染 `<Users>` 组件,并在其内部渲染 `<UserList>` 组件。当访问 `/users/123` 路径时,会仍然渲染 `<Users>` 组件,并在其内部渲染 `<UserDetails>` 组件。
希望这个示例对你有所帮助!
react-router-dom v6 嵌套路由
在React Router v6中,嵌套路由的使用方式略有不同。你可以使用`<Route>`组件来定义嵌套路由,并使用`element`属性指定要渲染的组件。下面是一个示例:
```jsx
import { Route, Routes } from 'react-router-dom';
import { News } from './News';
import { Message } from './Message';
export const Home = () => {
return (
<div>
<h3>Home</h3>
<div>
<ul className="nav nav-tabs">
<li>
<MyNavLink to="news">News</MyNavLink>
</li>
<li>
<MyNavLink to="message">Message</MyNavLink>
</li>
</ul>
{/* 注册路由 */}
<Routes>
<Route path="news" element={<News />} />
<Route path="message" element={<Message />} />
</Routes>
</div>
</div>
);
};
```
在上面的代码中,我们使用`<Routes>`组件包裹了多个`<Route>`组件,每个`<Route>`组件定义了一个嵌套路由的路径和要渲染的组件。例如,当路径为"/news"时,会渲染`<News>`组件。这样,当用户访问"/news"时,`<News>`组件就会被渲染在嵌套路由的位置上。
希望这能回答你的问题!<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [React Router v6 路由配置,嵌套路由](https://blog.csdn.net/Snow_GX/article/details/123656412)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *3* [react-router-dom v6版本 嵌套路由](https://blog.csdn.net/jzh1359314792/article/details/126526047)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文