react 判断是否登录,路由进行重定向

判断用户是否登录,从而进行路由的重定向。

  1. 创建文件 “./component/AuthRoute/index.js”
  2. 导入
import React, {useContext, createContext, useState} from "react";
import {
    BrowserRouter as Router,
    Switch,
    Route,
    Link,
    //Redirect重定向组件
    Redirect,
    useHistory,
    useLocation
} from "react-router-dom";
//isAuth为判断Token是否存在,即判断用户是否登录
import {isAuth,} from "../../utils/auth"
  1. 封装重定向组件
const AuthRoute = ({component: Component, ...res}) => {
    return <Route
        {...res}
        render={props => {
            const isLoging = isAuth();

            if (isLoging) {
                //已经登录
                return <Component {...props}/>
            } else {
                //未登录
                return <Redirect to={{
                    pathname: "/login",
                    state: {
                        form: props.location,
                    }
                }}/>
            }
        }}/>
}
  1. 使用
    在app.js文件中导入
    //导入路由重定向
    import AuthRoute from “./component/AuthRoute”;

将需要进行判断用户是否登录才能展示的路由进行替换

 <Route path="/map" component={MyMap}/>
 //替换
 <AuthRoute path="/map" component={MyMap}/>

即可实现未登录重定向到登录页面

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值