美文网首页
react-路由守卫-路由 5x

react-路由守卫-路由 5x

作者: 云高风轻 | 来源:发表于2023-05-05 08:53 被阅读0次

1. 前言

  1. react 中路由守卫 提的比较少
  2. 这个是写的 react-router-dom 5x的路由守卫一种写法
  3. 写法有很多种 .都是条件渲染,仅供参考

2. 逻辑

  1. 在React中,路由守卫可以通过使用React Router实现。React Router提供了一个名为<Route>的组件,可以用来定义路由和其对应的组件。你可以通过在<Route>组件上添加一个render属性,来自定义路由守卫逻辑。

3. 简单的React路由守卫的示例代码

import React from "react";
import { BrowserRouter as Router, Route, Redirect } from "react-router-dom";

// 需要进行路由守卫的组件
const PrivateComponent = () => <h1>Private Component</h1>;

// 路由守卫
const AuthGuard = ({ component: Component, ...rest }) => (
  <Route {...rest} render={(props) =>
      isLoggedIn() // 自定义判断登录状态的函数
        ? <Component {...props} />
        : <Redirect to={{ pathname: '/login' }} />
    }
  />
);

// App组件
const App = () => (
  <Router>
    <div>
      <h1>React Router Demo</h1>
      <AuthGuard path="/private" component={PrivateComponent} />
    </div>
  </Router>
);

// 自定义函数:判断用户是否已登录
const isLoggedIn = () => {
  // 判断用户是否已经登录,返回 true 或 false
  return true;
}

export default App;

4. 分析

  1. AuthGuard是我们自己定义的一个组件,它接收一个component属性和其他路由属性(例如path)
  2. 并在render函数中进行路由守卫逻辑。
  3. 如果用户已登录,AuthGuard会渲染传入的组件,
  4. 否则它会重定向到登录页面。
  5. 在App组件中,我们将AuthGuard用于需要进行路由守卫的组件。

  1. 当用户访问私有页面(例如“/private”)时,React Router会自动调用AuthGuard组件,并根据登录状态判断是否展示PrivateComponent组件。如果用户未登录,AuthGuard会将页面重定向到登录页面。

当然,上面的代码只是一个简单的示例。在实际开发中,你可能需要根据自己的需求来定制路由守卫逻辑,例如添加登录逻辑、验证用户权限等。


参考资料


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉

相关文章

  • vue的路由守卫

    路由守卫分3种:全局守卫路由独享守卫组件内的路由守卫 1.全局守卫:beforeEachbeforeResolve...

  • Vue嵌套路由和路由守卫

    嵌套路由 路由守卫

  • [VUE]动态的更新页面的Title

    首先可以用路由守卫 + VueRouter来实现路由守卫相关文档1.main.js里加入路由守卫 // 页面修改时...

  • vue的路由和路由守卫

    router 和 路由守卫 路由配置 分模块配置 404 配置 懒加载 active-class 路由守卫(跟 a...

  • vue路由守卫

    概念 路由守卫,官网也叫导航守卫,所谓导航,就是路由正在发生变化 路由守卫,主要就是用来通过跳转或取消的方式守卫导...

  • angularjs路由守卫

    什么是路由守卫及路由守卫的用处: 路由守卫就是angularjs为我们提供的路于钩子函数,当我们进入或离开某个...

  • 路由守卫

    路由守卫分为三种 全局守卫: 路由独享守卫卸载route里 组件内守卫:写在组件配置对象里

  • Vue-Router 导航守卫

    导航守卫 导航表示路由正在发生改变。(变化的路由)导航守卫就是变化的路由钩子。路由钩子的意思可以理解为vue-ro...

  • 路由

    全局守卫就是每一个路径进来都会经过这个全局守卫的处理 单路由守卫就是把守卫指定给某一个路由 组件内路由就是把守卫放...

  • vue权限路由实现方式总结

    使用全局路由守卫 实现 前端定义好路由,并且在路由上标记相应的权限信息 全局路由守卫每次都判断用户是否已经登录,没...

网友评论

      本文标题:react-路由守卫-路由 5x

      本文链接:https://www.haomeiwen.com/subject/sobfsdtx.html