基于react-routet v7 的配置式 + 约定式路由系统 第一步:引入react-routerv7

这是本专栏的第一篇文章,用来记录一个基于react-router v7 的路由系统的从创建到完善的过程,以及过程中的思考 ~

概览

react-router-dom 安装 与 antd 组件结合实现基础路由系统

先来大致回顾一下 react-touter v7 的重要变化

  1. React 19 支持 - v7 针对 React 19 做了适配
  2. 非破坏性升级 - 从 v6 升级到 v7 不会破坏现有代码
  3. 框架化定位 - v7 定位为全栈框架,支持数据加载等新特性

react-router-dom

首先我们需要将 react-router 引入 reactv19。这里我选择使用 react-router-dom v7 .

shell 复制代码
npm install react-router-dom

补充: 是 react-router浏览器环境下的专门实现(DOM 环境) ,它依赖并封装了 react-router ,在核心库的基础上,增加了适合浏览器环境的路由组件和功能(如 BrowserRouterHashRouterLink 等)。

页面配置

js 复制代码
import { BrowserRouter, Routes, Route } from 'react-router-dom'   
function App() {     
    return (       
        <BrowserRouter>         
            <Routes>           
                {/* Layout 在 React Router 中的使用方式是作为父路由, 通过 <Outlet /> 来渲染子路由的内容 */} 
                <Route path="/" element={<Layout />}> 
                    <Route index path="chat" element={<Chat />}></Route> 
                    <Route path="shiti" element={<ShiTi />}></Route> 
                    <Route path="file" element={<UploadPage />}></Route> 
                    </Route>         
                </Routes>       
         </BrowserRouter>     
     )   
}

layout.tsx --- 结合antd 的 Menu 组件进行配置

js 复制代码
import { Menu } from "antd" 
import { Outlet } from "react-router-dom"; 
import useRouterHook from './useRouterHook'; 
import * as styles from './index.module.less'; 

const Layout = () => { 
    const { onClick, current, items } = useRouterHook(); 
    
    return ( 
        <div className={styles.container}> 
            <Menu 
                className={styles.menu} 
                onClick={onClick} 
                selectedKeys={[current]} 
                mode="horizontal" 
                items={items} 
            /> 
            <div className={styles.main}> 
                <Outlet /> 
            </div> 
        </div> 
     ) 
} 

export default Layout;

封装 useRouterHook

思路:

  1. 将 文件路径做为 key 存放到 Menu 的item 中,
  2. 点击 Menu 触发 onClick 事件,使用 useNavigator 进行路由切换
  3. 监听 useLocation 的 pathname 属性,页面路由发生变化的时候,改变当前 current menu 值
tsx 复制代码
import { MenuProps } from "antd"; 
import { useEffect, useState } from "react"; 
import { AppstoreOutlined, MailOutlined, SettingOutlined } from '@ant-design/icons'; 
import { useLocation, useNavigate } from "react-router-dom"; 

const useRouterHook = () => { 
    const navigate = useNavigate(); 
    const location = useLocation(); 
    type MenuItem = Required<MenuProps>['items'][number]; 
    const items: MenuItem[] = [ 
        { label: "聊天", key: "/chat", icon: <AppstoreOutlined />, }, 
        { label: "试题", key: "/shiti", icon: <MailOutlined /> }, 
        { label: "文件", key: "/file", icon: <SettingOutlined /> } 
    ] 
    const [current, setCurrent] = useState<string>('/chat') 
    const onClick:MenuProps['onClick'] = (e) => { 
        setCurrent(e.key) navigate(e.key) 
    } 
    
    useEffect(() => { 
        setCurrent(location.pathname) 
    }, [location.pathname]) 
    
    return { current, onClick, items } 
} 

export default useRouterHook

页面效果:

OK,接入完成

下一步,利用webpack 编译时注入的变量 require 实现约定式路由 ~ juejin.cn/post/759366...

相关推荐
用户35020158847482 小时前
基于react-routet v7 的配置式 + 约定式路由系统 第二步:一个简单的约定式路由系统
前端
攀登的牵牛花2 小时前
前端向架构突围系列 - 框架设计(七):反应式编程框架Flower的设计
前端·架构
佛系打工仔2 小时前
K线绘制前言
前端
遇见~未来2 小时前
JavaScript数组全解析:从本质到高级技巧
开发语言·前端·javascript
石像鬼₧魂石2 小时前
80 端口(Web 服务)渗透测试完整总结(含踩坑 + 绕过 + 实战流程)
linux·运维·服务器·前端·网络·阿里云
C_心欲无痕3 小时前
nginx - 核心概念
运维·前端·nginx
开开心心_Every3 小时前
安卓做菜APP:家常菜谱详细步骤无广简洁
服务器·前端·python·学习·edge·django·powerpoint
前端_Danny3 小时前
用 ECharts markLine 实现节假日标注
前端·信息可视化·echarts
古城小栈3 小时前
Rust 丰富&好用的 格式化语法
前端·算法·rust