277/300 React+react-router-dom+Vite 二级页面刷新时,白屏问题解决

(一)方案

BrowserRouter 换为 HashRouter

(二)代码

js 复制代码
import routes from './routes'
import  {ReactElement, Suspense} from 'react'
import {createHashRouter, Navigate} from 'react-router-dom'
// 生成路由数据
const generateRoutes = (routes:  Routes) => {
    return routes.map((item: RouteParams) => {
        const {component: Component} = item;
        const route: RouteObject = {path: item.path}

        if (item.redirect) {
            route.element = <Navigate to={item.redirect} replace/>
        } else if (Component) {
            route.element = <BeforeEach meta={item.meta} path={item.path}>
                <Suspense>
                    <Component/>
                </Suspense>
            </BeforeEach>
        }

        if (item.children) {
            route.children = generateRoutes(item.children)
        }

        return route
    })
}
export default createHashRouter(
    generateRoutes(routes)
)

(三)更多代码

js 复制代码
import routes from './routes'
import  {ReactElement, Suspense} from 'react'
import {createHashRouter, Navigate} from 'react-router-dom'
// 生成路由数据
const generateRoutes = (routes:  Routes) => {
    return routes.map((item: RouteParams) => {
        const {component: Component} = item;
        const route: RouteObject = {path: item.path}

        if (item.redirect) {
            route.element = <Navigate to={item.redirect} replace/>
        } else if (Component) {
            route.element = <BeforeEach meta={item.meta} path={item.path}>
                <Suspense>
                    <Component/>
                </Suspense>
            </BeforeEach>
        }

        if (item.children) {
            route.children = generateRoutes(item.children)
        }

        return route
    })
}

// 路由拦截器
const BeforeEach = (props: { meta?: RouteMeta, children: ReactElement, path: String; }) => {
    const { userStore } = useStores()

    const { meta, children, path } = props

    // 未登录
    if(meta){
        if(meta.isAuth && !userStore.isLogin || meta.userStatus && meta.userStatus !== userStore.info.status){
            return (
                <AutoReverse path={path} />
            )
        }
    }

    // 设置标题
    if (meta?.title) {
        document.title = meta.title
    }

    document.body.style.backgroundColor = meta?.backgroundColor || '';

    return children
}

export default createHashRouter(
    generateRoutes(routes)
)
相关推荐
OpenTiny社区1 小时前
重磅预告|OpenTiny 亮相 QCon 北京,共话生成式 UI 最新技术思考
前端·开源·ai编程
前端老实人灬1 小时前
web前端面试题
前端
Moment1 小时前
AI 全栈指南:NestJs 中的 Service Provider 和 Module
前端·后端·面试
IT_陈寒1 小时前
为什么我的JavaScript异步回调总是乱序执行?
前端·人工智能·后端
Moment1 小时前
AI全栈入门指南:NestJs 中的 DTO 和数据校验
前端·后端·面试
小码哥_常1 小时前
告别RecyclerView卡顿!8个优化技巧让列表丝滑如德芙
前端
小村儿1 小时前
Harness Engineering:为什么你用 AI 越用越累?
前端·后端·ai编程
FrontAI1 小时前
Next.js从入门到实战保姆级教程:环境配置与项目初始化
react.js·typescript·学习方法
enoughisenough2 小时前
浏览器判断控制台是否开启
前端
Moment2 小时前
当前端开始做 Agent 后,我才知道 LangGraph 有多重要❗❗❗
前端·后端·面试