React 6.4.0 所有路由器的通用標頭
P粉864872812
2023-08-25 17:19:53
<p>我正在使用 <code>react-router-dom</code> 版本 6.4.0 啟動 React 項目,但無法為所有路由建立通用標頭。 </p>
<p>App.js - 這是我新增 <code>RouterProvider</code></p> 的文件
<pre class="brush:php;toolbar:false;">import logo from './logo.svg';
import './App.css';
import { Link, Outlet, RouterProvider } from "react-router-dom";
import { routers } from "./routes/routes";
function App() {
return (
<RouterProvider router={routers}>
<div>Header</div>
<Outlet />
</RouterProvider>
);
}
export default App;</pre>
<p>routes.js - 在此文件中我將建立所有路線</p>
<pre class="brush:php;toolbar:false;">import { createBrowserRouter, redirect } from "react-router-dom";
import About from "../pages/About/About";
import Home from "../pages/Home/Home";
import { getUser, isAuthenticated } from "../sso/authUtil";
const authLoader = () => {
if (!isAuthenticated()) {
return redirect("https://google.com");
} else {
return getUser();
}
};
export const routers = createBrowserRouter([
{
path: "/",
element: <Home />,
loader: authLoader,
},
{
path: "/about",
element: <About />,
},
]);</pre>
<p>Home.js - 此文件是主頁,其中包含指向其他頁面的連結以及標題</p>
<pre class="brush:php;toolbar:false;">import React from "react";
import { Link, Outlet, useLoaderData } from "react-router-dom";
const Home = () => {
const loaderData = useLoaderData();
return (
<>
<div>Header</div>
<Link to="/">Home</Link>
<Link to="/about">About</Link>
<div>Home: {loaderData}</div>{" "}
<Outlet />
</>
);
}
export default Home;</pre>
<p>About.js - 這是一個普通的組件,表示關於</p>
<pre class="brush:php;toolbar:false;">import React from "react";
const About = () => {
return <div>About</div>;
};
export default About;</pre>
<p>我希望 <code>Home</code> 和 <code>About</code> 元件載入時標題位於頂部。 </p>
即使在
react-router-dom@6.4.0
中,使用通用 UI 渲染佈局路由仍然可以正常運作。建立一個渲染公共標頭元件的佈局路由元件和一個用於嵌套路由的
Outlet
。範例:
在配置中的佈局路由上匯入並渲染
Layout
。...