路由配置是项目开发的必要一环,尤其是目前流行SPA,下面看看如何使用v6版本路由进行合理的H5路由配置
 
一、基本页面结构(目录根据开发要求建,下面仅用于展示配置路由)
 

 
二、具体文件实现
 
1. index.tsx
 
import React from "react";
import ReactDOM from "react-dom/client";
import vconsole from "vconsole";
import { createBrowserRouter, RouterProvider } from "react-router-dom";
import "normalize.css/normalize.css";
import routes from "./router";
const BASENAME = "/h5";
const root = ReactDOM.createRoot(
  document.getElementById("root") as HTMLElement
);
const router = createBrowserRouter(routes, { basename: BASENAME });
root.render(
  <React.StrictMode>
    <RouterProvider router={router} />
  </React.StrictMode>
);
if (
  process.env.NODE_ENV === "development" ||
  window.location.search.includes("debug=true")
) {
  new vconsole();
}
 
2. App.tsx
 
import { Suspense } from "react";
import { AliveScope } from "react-activation";
import { Outlet } from "react-router-dom";
function App() {
  return (
    <Suspense>
      <AliveScope>
        {}
        <Outlet />
      </AliveScope>
    </Suspense>
  );
}
export default App;
 
3. ./router/index.tsx
 
import App from "@/App";
import type { RouteObject } from "react-router";
import { Navigate } from "react-router-dom";
import loadable from "@loadable/component";
import mainRoutes from "./mainRoutes";
import userRoutes from "./userRoutes";
const NotFound = loadable(() => import("@/pages/NotFound"));
let routes: RouteObject[] = [
  {
    path: "/",
    element: <App />,
    children: [mainRoutes, userRoutes],
  },
  
  {
    path: "*",
    element: <NotFound />,
  },
];
const Devtool = loadable(() => import("@/pages/Devtool"));
if (process.env.NODE_ENV === "development") {
  routes = [
    {
      path: "/",
      element: <Navigate to={"devtool"} replace />,
    },
    {
      path: "/devtool",
      element: <Devtool />,
    },
    ...routes,
  ];
}
export default routes;
 
4. ./router/mainRoutes.tsx
 
import type { RouteObject } from "react-router";
import KeepAlive from "react-activation";
import { lazy } from "react";
import { Navigate } from "react-router-dom";
const MainLayout = lazy(() => import("@/pages/Main/Layout"));
const MainList = lazy(() => import("@/pages/Main/List"));
const MainDetail = lazy(() => import("@/pages/Main/Detail"));
const mainRoutes: RouteObject = {
  path: "main",
  element: <MainLayout />,
  children: [
    
    {
      path: "",
      element: <Navigate to="list" replace />,
    },
    {
      path: "list",
      element: (
        <KeepAlive name="main-list">
          <MainList />
        </KeepAlive>
      ),
    },
    {
      path: "detail",
      element: <MainDetail />,
    },
  ],
};
export default mainRoutes;
 
5. ./router/userRoutes.tsx
 
import type { RouteObject } from "react-router";
import { lazy } from "react";
const UserLayout = lazy(() => import("@/pages/User/Layout"));
const UserInfo = lazy(() => import("@/pages/User/UserInfo"));
const userRoutes: RouteObject = {
  path: "user",
  element: <UserLayout />,
  children: [
    {
      path: "info",
      element: <UserInfo />,
    },
  ],
};
export default userRoutes;
 
6. Layout.tsx
 
import { Outlet } from "react-router-dom";
const Layout = () => {
  return <Outlet />;
};
export default Layout;