react-路由守卫-6x

简介: react-路由守卫-6x

1. 前言

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

2. 逻辑

  1. React Router 6 中,路由守卫的实现方式有所不同。React Router 6 引入了一个名为Routes的新组件,用于定义路由和路由守卫。
  2. 你可以在<Route>组件上使用一个when属性来定义路由守卫,也可以使用一个useNavigate钩子来进行编程式导航。

3. React Router 6版本中的路由守卫的示例代码:

import React from "react";
import { BrowserRouter as Router, Routes, Route, Navigate } from "react-router-dom";
// 需要进行路由守卫的组件
const PrivateComponent = () => <h1>Private Component</h1>;
// 路由守卫
const AuthGuard = ({ when, navigate, path, ...rest }) => {
  if (when) {
    return <Route {...rest} />;
  } else {
    navigate("/login");
    return null;
  }
};
// App组件
const App = () => (
  <Router>
    <div>
      <h1>React Router Demo</h1>
      <Routes>
        <AuthGuard
          path="/private"
          element={<PrivateComponent />}
          when={isLoggedIn()} // 自定义判断登录状态的函数
        />
      </Routes>
    </div>
  </Router>
);
// 自定义函数:判断用户是否已登录
const isLoggedIn = () => {
  // 判断用户是否已经登录,返回 true 或 false
  return true;
}
export default App;

4. 分析

  1. AuthGuard是我们自己定义的一个组件,它接收when属性和其他路由属性(例如path),
  2. 并在渲染时进行路由守卫逻辑。
  3. 如果用户已登录,AuthGuard会渲染传入的element组件
  4. 否则它会使用useNavigate钩子进行编程式导航,将页面重定向到登录页面。
  5. 在App组件中,我们使用Routes组件来定义路由,并将AuthGuard用于需要进行路由守卫的组件。

  1. 需要注意的是,在React Router 6 中,我们使用element属性来指定需要渲染的组件,而不是component属性。
  2. 此外,我们还需要使用useNavigate钩子来进行编程式导航,因为React Router 6 中不再支持this.props.history对象。

参考资料


初心

我所有的文章都只是基于入门,初步的了解;是自己的知识体系梳理,如有错误,道友们一起沟通交流;
如果能帮助到有缘人,非常的荣幸,一切为了部落的崛起;
共勉
相关文章
|
3月前
|
前端开发 JavaScript
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
本文介绍了在React项目中实现路由懒加载的方法,使用React提供的`lazy`和`Suspense`来优化项目首次加载的速度。通过将路由组件改为懒加载的方式,可以显著减少初始包的大小,从而加快首次加载速度。文章还展示了如何使用`Suspense`组件包裹`Switch`来实现懒加载过程中的fallback效果,并提供了使用前后的加载时间对比,说明了懒加载对性能的提升作用。
212 2
React项目路由懒加载lazy、Suspense,使第一次打开项目页面变快
|
1月前
|
前端开发 API UED
React 路由守卫 Guarded Routes
【10月更文挑战第26天】本文介绍了 React 中的路由守卫(Guarded Routes),使用 `react-router-dom` 实现权限验证、登录验证和数据预加载等场景。通过创建 `AuthContext` 管理认证状态,实现 `PrivateRoute` 组件进行路由保护,并在 `App.js` 中使用。文章还讨论了常见问题和易错点,提供了处理异步操作的示例,帮助开发者提升应用的安全性和用户体验。
48 1
|
1月前
|
前端开发 安全 网络安全
React——路由Route
React——路由Route
34 2
React——路由Route
|
2月前
|
资源调度 前端开发 测试技术
React Router 路由管理
【10月更文挑战第10天】本文介绍了 React Router,一个在 React 应用中管理路由的强大工具。内容涵盖基本概念、安装与使用方法、常见问题及解决方案,如路由嵌套、动态路由和路由守卫等,并提供代码示例。通过学习本文,开发者可以更高效地使用 React Router,提升应用的导航体验和安全性。
286 19
|
2月前
|
前端开发 网络架构
React 路由
10月更文挑战第11天
34 2
|
2月前
|
前端开发 JavaScript 网络架构
实现动态路由与状态管理的SPA——使用React Router与Redux
【10月更文挑战第1天】实现动态路由与状态管理的SPA——使用React Router与Redux
39 1
|
3月前
|
前端开发 Python
React技术栈-React路由插件之自定义组件标签
关于React技术栈中React路由插件自定义组件标签的教程。
59 4
React技术栈-React路由插件之自定义组件标签
|
3月前
|
移动开发 前端开发 应用服务中间件
React两种路由模式的实现原理
React两种路由模式的实现原理
97 3
|
3月前
|
前端开发 程序员 API
React技术栈-React路由插件之react-router的基本使用
这篇博客介绍了React路由插件react-router的基本使用,包括其概念、API、以及如何通过实战案例在React应用中实现SPA(单页Web应用)的路由管理。
76 9
|
4月前
|
前端开发 测试技术 开发者
React Router的神奇之处:如何用导航与路由管理让你的复杂SPA飞起来?
【8月更文挑战第31天】本文全面解析了React Router——一款用于React应用的路由与导航管理库。通过定义不同路径并依据URL渲染组件,React Router支持路径匹配、参数路由及嵌套路由等多种模式。文章详细介绍了其基本与高级用法,如使用`Link`组件导航、`Switch`组件进行路径匹配及`NavLink`自定义活动链接样式。此外,还探讨了懒加载、代码分割等性能优化技巧,并提供了简单示例代码,帮助读者快速上手。遵循本文最佳实践,开发者能够更高效地利用React Router构建复杂的单页面应用。
82 0