【无标题】

react router v6 路由 及路由拦截

项目场景:

项目场景:千锋React项目实战 全球新闻发布管理系统

学习笔记:

(1) React Router V6 : Route组件使用方法

//旧版本写法
<Route path="/login" element={<Login/>}/>
//V6版本写法
<Route path="/login" render={()=>{return <Login/>}/>

(2)V6版本实现 路由拦截

localStorage中token字段是否有值,如果有,到达NewsSandBox,没有到达Login界面

function IndexRouter(props) {
    // RequireAuth 组件相当于一个拦截器,是否返回被拦截的组件要听他的
    function RequireAuth({ children }) {
        const authed = localStorage.getItem('token')
        return authed !== null ? ( // 判断 localstorage 中登录状态是否为 true
            children
        ) : (
            <Navigate to="/login" replace /> // 跳转到登录
        );
    }
    return (
        <BrowserRouter>
            {/*path是模糊匹配,我们可以使用Routes组件,如果匹配到第一个之后,就不再继续往下匹配
            <Routes>不是按顺序扫描路由,而是自动为当前 URL 选择最好的路由。它还允许您在整个应用程序中传递路由*/}
            <Routes>
                <Route path="/login" element={<Login/>}/>
                {/*<Route path="/" element={<NewsSandBox/>}/>*/}
                {/*//如果刚开始登陆没有token字段(未授权),就重定向到Login*/}
                <Route path="/" element={
                    <RequireAuth> // 拦截组件
                        <NewsSandBox/> // 被拦截组件
                    </RequireAuth>
                }/>
            </Routes>
        </BrowserRouter>

    );
}

export default IndexRouter;

参考文章:https://blog.csdn.net/u014418267/article/details/121524573

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值