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)
)
相关推荐
如鹿觅水1 分钟前
通过JS删除当前域名中的全部COOKIE教程
服务器·前端·javascript
#sakura2 分钟前
web-02
前端
Lipn6 分钟前
前端怎么获取视口大小
开发语言·前端·javascript
晓风伴月7 分钟前
腾讯IM web版本实现迅飞语音听写(流式版)
前端·语音识别·讯飞语音听写
开心工作室_kaic1 小时前
ssm126基于HTML5的出租车管理系统+jsp(论文+源码)_kaic
java·前端·html5
超*2 小时前
腾讯云产品推荐----域名的使用
前端·javascript·腾讯云
苹果电脑的鑫鑫2 小时前
uni-app使用watch监听数据,当数据变化时页面没有根据变化数据渲染解决方法
java·前端·uni-app
小沐在学习3 小时前
第六章元素应用CSS
前端·css
竹秋…3 小时前
vue3+element-plus==> el-form输入响应式失效踩坑!!!!!!!!!!
javascript·vue.js·elementui
晨曦_子画3 小时前
将 HTML 转换为 JSX:JSX 和 JSX 规则
前端·javascript·html