簡單介紹下項目背景,我這里做了一個demo,前端使用mock數據,然后實現簡單的路由攔截,校驗session是否包含用戶作為已登錄的依據,react-router-dom是v6。不像vue可以設置登錄攔截beforeenter,react需要我們自己加。
//router.js
import React, { lazy } from "react";
import { Navigate } from 'react-router-dom'const Error = lazy(() => import("@/pages/Error/Error.jsx"))
const Index = lazy(() => import("@/pages/Index/Index.jsx"))
const Login = lazy(() => import("@/pages/Login/Login.jsx"))export const routes = [{path: "/",element: <Navigate to="/index"/>},{path: "/login",element: <Login />},{path: "/index",element: <Index />},{path: "*",element: <Error />},
]
import React, { useEffect, Suspense } from 'react'
import { useRoutes, useNavigate } from 'react-router-dom'
import { routes } from './router'export default function Index() {const element = useRoutes(routes)return (<Authen route={element} children={element.children}><Suspense><div>{element}</div></Suspense></Authen>)}
//實現路由攔截
const Authen = (props) => {const navigate = useNavigate()const { route, children } = propsconst username = sessionStorage.getItem('username')console.log(props);useEffect(() => {if (route.props.match.pathname === "/login" && username) {navigate('/index')}}, [route, navigate,username])return children
}
Surpense組件是react組件懶加載的時候,路由跳轉了,由于網絡原因,組件內容無法及時過去,不添加會報錯。?