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 />
    }
] 
相关推荐
xiangxiongfly91520 分钟前
uni-app 组件总结
前端·javascript·uni-app
SwJieJie27 分钟前
Day1 从 0 搭建 VueDemo Web Admin 项目环境:技术栈、插件链与自动化脚本全解析
前端·vue.js·学习
wordbaby29 分钟前
React 自定义 Hook 实践:如何优雅管理复杂列表的筛选状态?
前端
xuankuxiaoyao29 分钟前
Vue.js 插槽、作用域插槽、商品、阶段案例
android·vue.js·flutter
EF@蛐蛐堂31 分钟前
TanStack NPM攻击 揭秘及应对方案
前端·vue.js·npm·安全威胁分析
恋猫de小郭34 分钟前
终于,Flutter 修复 Android 中文字体异常,但是很草台,不知怎么吐槽
android·前端·flutter
Cobyte37 分钟前
11.响应式系统演进:深入剖析 computed 实现原理与性能优化实践(Vue3.3)
前端·javascript·vue.js
_Evan_Yao37 分钟前
计算机大一新生如何选择方向(前端/后端/AI/运维)?
运维·前端·人工智能·后端
ZC跨境爬虫37 分钟前
跟着MDN学HTML_day_46:(HTMLCollection与NodeList)
前端·javascript·ui·html·音视频