react_13

React Router

//-dom代表给浏览器应用使用的

npm install react-router-dom

  • 目前版本是 "react-router-dom": "^6.18.0"

使用

新建文件 src/router/MyRouter.tsx
*

TypeScript 复制代码
import { Navigate, RouteObject, useRoutes } from "react-router-dom";
import { Route } from "../model/Student";
import A8Login from "../pages/A8Login";
import A8Main from "../pages/A8Main";
import A8NotFound from "../pages/A8NotFound";
import { lazy } from "react";
import RoutesStore from "../store/RoutesStore";
import { observer } from "mobx-react-lite";
export function load(name: string) {
  //lazy方法可以根据字符串获得字符串组件对应着的组件标签
  const Page = lazy(() => import(`../pages/${name}`));
  console.log(Page);
  return <Page></Page>;
}
 function MyRouter() {
  console.log(RoutesStore.routes)
  const router = useRoutes(RoutesStore.routes);
  return router;
}
//注意导入 router 对象时,用 observer 做了包装,这样能够在 store 发生变化时重建 router 对象
export default observer(MyRouter)

index.tsx 修改为
*

TypeScript 复制代码
import ReactDOM from "react-dom/client";
import "./index.css";

import reportWebVitals from "./reportWebVitals";

import { ConfigProvider } from "antd";
import zhCN from "antd/es/locale/zh_CN";

import MyRouter from "./router/MyRouter";
import { BrowserRouter } from "react-router-dom";
const root = ReactDOM.createRoot(
  document.getElementById("root") as HTMLElement
);

root.render(
  <ConfigProvider locale={zhCN}>
    <BrowserRouter>
      <MyRouter></MyRouter>
    </BrowserRouter>
  </ConfigProvider>
);

// If you want to start measuring performance in your app, pass a function
// to log results (for example: reportWebVitals(console.log))
// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals
reportWebVitals();

A8Main 的代码
*

TypeScript 复制代码
import {
  DownCircleOutlined,
  MenuFoldOutlined,
  VerticalAlignTopOutlined,
} from "@ant-design/icons";
import { Button, Layout, Menu } from "antd";
import { ItemType } from "antd/es/menu/hooks/useItems";
import { Link, Navigate, Outlet, useNavigate } from "react-router-dom";
import Icon from "../store/Icon";
import StudentStore from "../store/StudentStore";
import RoutesStore from "../store/RoutesStore";
import { observer } from "mobx-react-lite";
import { useEffect } from "react";

function A8Main() {
  const items: ItemType[] = [
    {
      label: <Link to="/student">学生管理</Link>,
      key: 1,
      icon: <DownCircleOutlined />,
    },
    {
      label: <Link to="/teacher">教师管理</Link>,
      key: 2,
      icon: <VerticalAlignTopOutlined />,
    },
    {
      label: "用户管理",
      key: 3,
      icon: <MenuFoldOutlined />,
      children: [
        {
          label: "功能一",
          key: 31,
          icon: <Icon name="PicLeftOutlined"></Icon>,
        },
        {
          label: "功能二",
          key: 32,
          icon: <Icon name="BorderHorizontalOutlined"></Icon>,
        },
      ],
    },
  ];
  const nav = useNavigate();
  //点击注销按钮,清空localStorage里面和state数据,跳转到登录页面
  function onClick() {
    RoutesStore.reset();
    nav("/login");
  }
  //useEffect()的执行时机是先生成了jsx代表,然后执行了副作用,然后再渲染,正在渲染的时候执行了跳转,所以看到
  //主页一闪而过,
  /* useEffect(() => {
    if (RoutesStore.username === "") {
      nav("/login");
    }
  }, []); */
  if (RoutesStore.username === "") {
    return <Navigate to={"/login"}></Navigate>;
  }
  return (
    <Layout>
      <Layout.Header>
        <span>欢迎您【{RoutesStore.username}】</span>
        <Button onClick={onClick}>注销</Button>
      </Layout.Header>
      <Layout>
        <Layout.Sider>
          <Menu items={RoutesStore.menus} theme="dark" mode="inline"></Menu>
        </Layout.Sider>
        <Layout.Content>
          <Outlet></Outlet>
        </Layout.Content>
      </Layout>
    </Layout>
  );
}
export default observer(A8Main);
  • Navigate 的作用是重定向

  • load 方法的作用是懒加载组件,更重要的是根据字符串找到真正的组件,这是动态路由所需要的

  • children 来进行嵌套路由映射,嵌套路由在跳转后,并不是替换整个页面,而是用新页面替换父页面的 Outlet 部分

相关推荐
无咎.lsy2 分钟前
vue之vuex的使用及举例
前端·javascript·vue.js
fishmemory7sec9 分钟前
Electron 主进程与渲染进程、预加载preload.js
前端·javascript·electron
fishmemory7sec12 分钟前
Electron 使⽤ electron-builder 打包应用
前端·javascript·electron
豆豆1 小时前
为什么用PageAdmin CMS建设网站?
服务器·开发语言·前端·php·软件构建
JUNAI_Strive_ving1 小时前
番茄小说逆向爬取
javascript·python
看到请催我学习2 小时前
如何实现两个标签页之间的通信
javascript·css·typescript·node.js·html5
twins35202 小时前
解决Vue应用中遇到路由刷新后出现 404 错误
前端·javascript·vue.js
qiyi.sky2 小时前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~2 小时前
分析JS Crash(进程崩溃)
java·前端·javascript
哪 吒2 小时前
华为OD机试 - 几何平均值最大子数(Python/JS/C/C++ 2024 E卷 200分)
javascript·python·华为od