React+vite+antd点击路由切换时出现闪屏

问题描述:点击左侧路由切换会出现闪屏的情况

页面的效果

解决方案

完整代码

javascript 复制代码
import { lazy, Suspense, ReactNode } from "react";
import { Navigate, useLocation } from "react-router-dom";
import LayOut from '../pages/LayOut/LayOut'
import NotFound from '../pages/NotFound/NotFound'
const LoginIndex = lazy(() => import('../pages/LoginIndex/LoginIndex'))
const DashBoard = lazy(() => import('../pages/DashBoard/DashBoard'))
const UserInfo = lazy(() => import('../pages/UserInfo/UserInfo'))
const SettingPage = lazy(() => import('../pages/SettingPage/SettingPage'))
const ItemList = lazy(() => import('../pages/ItemList/ItemList'))
const GoodsList = lazy(() => import('../pages/GoodsList/index'))
const BannerList = lazy(() => import('../pages/BannerList/index'))

const laztRoutes = (element: ReactNode): ReactNode => {
    return <Suspense fallback={<div>Loading...</div>}>
        {element} </Suspense>
}

const RequireAuth = ({ children }: { children: ReactNode }): ReactNode => {
    const location = useLocation();
    const token = localStorage.getItem('token'); // 假设token存储在localStorage中

    if (!token) {
        return <Navigate to="/login" state={{ from: location }} replace />;
    }

    return children;
}

export default [
    {
        path: '/',
        element: <Navigate to='/dashboard' />,
    },
    {
        path: '/',
        element: <RequireAuth><LayOut /></RequireAuth>,
        children: [

            {
                path: '/dashboard',
                element: laztRoutes(<DashBoard />)
            },
            {
                path: '/userinfo',
                element: laztRoutes(<UserInfo />)
            },
            {
                path: '/setting',
                element: laztRoutes(<SettingPage />)
            },
            {
                path: '/itemlist',
                element: laztRoutes(<ItemList />)
            },
            {
                path: '/goods',
                element: laztRoutes(<GoodsList />)
            },
            {
                path: '/banner',
                element: laztRoutes(<BannerList />)
            }
        ]
    },
    {
        path: '/login',
        element: <LoginIndex />
    },
    {
        path: '*',
        element: <NotFound />
    }
] 
相关推荐
Mintopia几秒前
Three.js 深度冲突:当像素在 Z 轴上玩起 "挤地铁" 游戏
前端·javascript·three.js
Penk是个码农5 分钟前
web前端面试-- MVC、MVP、MVVM 架构模式对比
前端·面试·mvc
markyankee1017 分钟前
Vue.js 入门指南:从零开始构建你的第一个应用
vue.js
MrSkye8 分钟前
🔥JavaScript 入门必知:代码如何运行、变量提升与 let/const🔥
前端·javascript·面试
白瓷梅子汤12 分钟前
跟着官方示例学习 @tanStack-form --- Linked Fields
前端·react.js
爱学习的茄子16 分钟前
深入理解JavaScript闭包:从入门到精通的实战指南
前端·javascript·面试
zhanshuo1 小时前
不依赖框架,如何用 JS 实现一个完整的前端路由系统
前端·javascript·html
火柴盒zhang1 小时前
websheet在线电子表格(spreadsheet)在集团型企业财务报表中的应用
前端·html·报表·合并·spreadsheet·websheet·集团财务
讨厌吃蛋黄酥1 小时前
智能前端新纪元:语音交互技术与安全实践全解析
javascript
khalil1 小时前
基于 Vue3实现一款简历生成工具
前端·vue.js