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 />
    }
] 
相关推荐
众智创新团队11 分钟前
关于Activity的六个常用控件和ListView控件的详情
开发语言·javascript·ecmascript
智模睿脑君24 分钟前
Streamlit快速构建大模型前端框架
人工智能·python·机器学习·语言模型·自然语言处理·前端框架·word2vec
奇舞精选1 小时前
AI Agent自动化操作浏览器的发展与应用
前端·openai
桔子爱笑1 小时前
vuex的基本使用
前端·javascript·vue.js
一路向前的月光1 小时前
React(7)
前端·javascript·react.js
helloweilei1 小时前
Webpack中使用@svgr/webpack处理SVG文件
前端
Nyingchi_X1 小时前
js运行机制(事件循环Event Loop、宏任务与微任务、浏览器事件循环与Nodejs事件循环的区别)
前端
2301_793069821 小时前
前后端分离的网页游戏,后端spring boot,前端vite+vue
前端·后端·vue·springboot·全栈
袋鼠云数栈UED团队1 小时前
Monaco Editor 实现在线版 Copilot
前端·react.js·aigc
刺客-Andy1 小时前
React 第二十五节 <Fragment></Fragment> 的用途以及使用注意事项详解
前端·react.js·前端框架