0

0

了解具有正确路由的 React Outlet

DDD

DDD

发布时间:2024-10-20 08:06:17

|

637人浏览过

|

来源于dev.to

转载

了解具有正确路由的 react outlet

本文将探讨 react 出口的功能以及 react 应用程序中的路由基础知识。首先也是最重要的,我们需要了解路由的基础知识

了解基础知识

在深入研究之前,让我们确保我们对 react router 有深入的了解。

  • 什么是 react router? ​​react router 是一个流行的 javascript 库,可以在 react 应用程序中的不同视图之间进行导航。它允许您定义路由,将 url 映射到特定组件。更多..

  • 为什么路由很重要?路由对于构建单页应用程序 (spa) 至关重要,用户无需重新加载整页即可导航,从而创建更流畅、更动态的体验。

现在让我们深入了解 react outlet

什么是 react outlet?

组件是父路由组件中的占位符,它告诉 react router 在哪里渲染子路由。它就像一个动态容器,根据当前 url 更改其内容。
此功能有助于管理复杂的布局,其中页面的一部分保持一致,例如标题或侧边栏,而其他部分则根据路线动态变化。

它是如何工作的:当 url 与父路由匹配时,react router 会在该父组件中查找 。然后它将匹配的子路由的组件渲染 中。

让我们为 react 应用程序使用正确的 react 路由来实现 outlet

import react from "react";

// import components
import allroutes from "./routes";

// component
const app = () => {
  return (
    <>

      
    
  );
};
export default app;

这个allroutes组件使用react-router-dom为react应用程序定义了一个路由系统,它处理react web应用程序中不同页面之间的导航。这是代码的详细分解

// import packages

import { browserrouter, outlet, route, routes } from "react-router-dom";
import react, { suspense, lazy } from "react";
import {
  dashboard,
  homepath,
  loginpath,
  rootpath
} from "./routepaths";

import loader from "../components/loader";
import protectedroute from "./protectedroute";

// import route paths

const logincomponent = lazy(() => import("../pages/login"));
const homecomponent = lazy(() => import("../pages/home"));
const routenotfoundcomponent = lazy(() => import("../pages/pagenotfound"));

const dashboardcomponent = lazy(() => import("../pages/dashboard/"));

const allroutescomponent = () => {
  return (
    }>
      
        
          }>
            } />
            } />
            }>
              } />
              } />
            
            } />
          
        
      
    
  );
};

export default allroutescomponent;

导入包

browserrouter:该组件支持在浏览器中进行路由。它使用 html5 历史 api 来保持 ui 与 url 同步。
outlet、route、routes:这些组件定义和处理应用程序中的各种路由(或页面)。
suspense:suspense 用于处理延迟加载的组件。它在加载组件时显示后备组件(在本例中为自定义加载器)。
惰性:此函数仅在需要时才延迟加载组件,从而实现代码分割,通过减少初始包大小来提高应用程序的性能。
加载器:这是一个自定义组件,在延迟加载组件时显示加载指示器。
protectedroute:此自定义组件可确保某些路由只能由授权用户访问,从而增强安全性。
根路由(/):该路由用于我们应用程序的根路径。它呈现登录组件。

导入路线

应用程序从单独的文件 (routepaths) 导入预定义路径(例如仪表板、homepath、loginpath、rootpath)。这使得代码更容易维护,并避免在组件内硬编码路由路径。

在 allroutescomponent 中定义路由

主函数 allroutescomponent 定义了如何处理应用程序中的不同路由:
:包装路由结构并管理浏览器导航。
:该组件保存应用程序的所有定义的路由。
:定义单个路由。 path 属性定义 url 模式,element 属性指定要为该路由渲染的组件。

  • 根 (rootpath) 路由充当子路由的容器。

    无线网络修复工具(电脑wifi修复工具) 3.8.5官方版
    无线网络修复工具(电脑wifi修复工具) 3.8.5官方版

    无线网络修复工具是一款联想出品的小工具,旨在诊断并修复计算机的无线网络问题。它全面检查硬件故障、驱动程序错误、无线开关设置、连接设置和路由器配置。 该工具支持 Windows XP、Win7 和 Win10 系统。请注意,在运行该工具之前,应拔出电脑的网线,以确保准确诊断和修复。 使用此工具,用户可以轻松找出并解决 WiFi 问题,无需手动排查故障。它提供了一键式解决方案,即使对于非技术用户也易于使用。

    下载
  • 当用户访问 / 路径时,索引路由默认渲染 logincomponent。

  • /login 路径也会渲染 logincomponent。

  • 像 /home 和 /dashboard 这样的路由被包装在 protectedroute 组件中,确保只有授权用户才能访问这些页面。

:这允许渲染嵌套路由。任何子路由(如 /login、/home)都会在父路由 (rootpath) 内呈现。

受保护的路线有哪些?

一些路由(如 homepath 和仪表板)嵌套在 protectedroute 元素内。这意味着用户必须满足某些条件(例如登录)才能访问这些页面。如果用户未经授权,protectedroute 组件通常会将其重定向到登录页面或错误页面。
这是受保护路线的代码

// import packages
import react, { useeffect } from "react";
import { usenavigate, outlet } from "react-router-dom";

import baselayout from "../pages/layout";

// import route paths
import { rootpath } from "./routepaths";

// component
const protectedroute = () => {
  const navigate = usenavigate();();
  const isauthenticated = false; //add a dynamic method call
  const user = 'shruti';//add a dynamic method call

  useeffect(() => {
    if (!isauthenticated) {
      return navigate(rootpath, { replace: true });
    }
  }, [isauthenticated, navigate]);

  return (
    
      
    
  );
};

export default protectedroute;

代码说明

  • 导入包

react, { useeffect }:react 是构建 ui 的核心包,useeffect 是在功能组件中运行副作用的钩子。这里,useeffect 用于处理用户未通过身份验证时的重定向。
usenavigate:react-router-dom 中的这个钩子可以实现编程导航。它用于在用户未经身份验证时重定向用户。
outlet:这是受保护路由内嵌套路由的占位符。它允许动态渲染子路由。
baselayout:该组件用布局包装受保护的路由,为受保护的页面提供一致的外观和结构。

  • 组件定义

usenavigate():这个钩子允许导航到不同的路线。在本例中,如果用户未经过身份验证,它用于导航到 rootpath。
isauthenticated 和 user:这些值目前是硬编码的,但可以动态设置,通常通过从全局状态或上下文检查某些身份验证状态(如 jwt 令牌、会话数据等)。
isauthenticated:确定用户是否通过身份验证的标志。如果为 false,则用户将被重定向。
user:当前登录的用户。该值可以从上下文或全局状态动态检索,但目前,它是一个硬编码字符串('shruti')。

useeffect:只要经过身份验证或导航更改,useeffect 挂钩就会运行。
在 useeffect 内部,代码检查用户是否经过身份验证。如果没有(!已通过身份验证),则使用导航功能将用户重定向到根路径。
{ replace: true } 选项可防止将重定向添加到浏览器的历史记录中,这意味着用户将无法导航回受保护的页面。

现在让我们深入了解 baselayout 组件代码

import React, { lazy } from "react";

import ErrorBoundary from "../../components/error-boundary";

// const Header = lazy(() => import("@components/header"));
const Sidebar = lazy(() => import("../../components/sidebar"));
export default function BaseLayout(props) {
  const { children } = props;
  // common things we need to show on each page like Header,sidebar ,Footer
  return (
    
      
{/*
*/} {children}//components from all routes
); } BaseLayout.defaultProps = { children: [], user: {},

baselayout 组件充当我们应用程序中所有页面的通用布局结构。
它包含侧边栏和主要内容区域等常见元素。
来自不同路由的子组件使用主内容区域内的 outlet 组件进行渲染。

试试这篇文章,用routeroutlet实现延迟加载路由

结论

react 中使用 outlet 进行延迟加载路由是通过减少应用程序的初始加载时间来优化性能的强大方法。通过使用 react.lazy() 和 suspense,您可以确保仅在需要时加载组件,而 outlet 组件则允许高效的嵌套路由。与受保护路由的使用相结合,此方法提供了一个模块化、可扩展且性能友好的结构,用于管理应用程序中的路由。

就是这样!

尝试一下,并在评论中告诉我你的想法!

相关文章

路由优化大师
路由优化大师

路由优化大师是一款及简单的路由器设置管理软件,其主要功能是一键设置优化路由、屏广告、防蹭网、路由器全面检测及高级设置等,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

557

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

394

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

754

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

478

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

1031

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

658

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

553

2023.09.20

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.3万人学习

React 教程
React 教程

共58课时 | 3.9万人学习

Bootstrap4.x---十天精品课堂
Bootstrap4.x---十天精品课堂

共22课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号