【八股系列】介绍React高阶组件,适用于什么场景?

news2025/1/17 21:53:52

文章目录

  • 1. HOC的工作原理
  • 2. 返回的新组件
  • 3. 适用场景
  • 4. 注意事项
  • 5. 示例代码

React高阶组件( Higher-Order Components,简称HOC)是 React中一种高级的 复用组件逻辑的技术。 HOC自身不是 React API的一部分,而是基于 React的组合性质( Composition)发展出来的一种编程模式。它是一个 接受组件作为参数并返回一个新的组件的函数

1. HOC的工作原理

HOC通过接收一个组件作为参数,可以对其进行以下操作:

  • 修改传入组件的props
  • 包装传入组件,提供额外的UI或行为
  • 处理状态或生命周期方法
  • 添加副作用,如订阅或日志记录

2. 返回的新组件

返回的新组件通常基于原组件进行了某种增强,比如添加了新的功能、进行了性能优化实现了复用的逻辑,而无需修改原组件的代码。

3. 适用场景

  • 复用组件逻辑:当多个组件需要共享某些功能时(如数据获取、权限验证、UI主题切换),可以通过HOC封装这些通用逻辑,减少代码重复。

  • 状态管理:结合Redux或其他状态管理库时,HOC可以用来连接组件到store,使得组件能够访问全局状态。

  • 权限控制:实现用户权限验证,只有满足特定条件的用户才能看到或操作组件内容。

  • 性能优化:通过实现shouldComponentUpdate生命周期方法或使用React.memo等手段,HOC可以帮助提升组件的渲染性能。

  • 布局与样式封装:统一处理页面布局或应用全局样式,如在组件外部添加固定的页头和页脚。

  • 数据操作:在组件渲染之前对数据进行预处理,如过滤、排序或格式化数据。

4. 注意事项

  • HOC应当遵循纯函数的原则,即对于相同的输入始终产生相同的输出,不引起副作用。
  • 使用HOC时应注意不要过度封装,以免造成组件层级过深,难以理解和维护。
  • 随着ReactHooks的普及,某些HOC的使用场景可以用自定义Hook替代,以获得更清晰的逻辑和更好的可读性。

5. 示例代码

下面是一个React高阶组件(HOC)的基本代码示例。HOC通过对布尔值的处理来决定是否渲染被包装的组件。

// withAuthentication.tsx
import React from 'react';

// 定义withAuthentication高阶组件
const withAuthentication = (WrappedComponent: React.ComponentType<any>) => {
  // 返回一个新的组件
  return class extends React.Component<any> {
    render() {
      // 确保isAuthorized是从props接收的
      const { isAuthorized } = this.props;

      // 根据isAuthorized的值决定是否渲染WrappedComponent
      return isAuthorized ? <WrappedComponent {...this.props} /> : <div>Unauthorized</div>;
    }
  };
};

export default withAuthentication;
// MyProtectedComponent.tsx
import React from 'react';
import withAuthentication from './withAuthentication';

// 一个简单的受保护的组件示例
class MyProtectedComponent extends React.Component {
  render() {
    return <div>Welcome to the protected content!</div>;
  }
}

// 使用withAuthentication装饰MyProtectedComponent
const ProtectedComponent = withAuthentication(MyProtectedComponent);

// 渲染ProtectedComponent,并传递isAuthorized为props
export default function AuthenticatedProtectedComponent() {
  return <ProtectedComponent isAuthorized={true} />;
}
// App.tsx
import React from "react";
import "./App.css";
......
import MyProtectedComponent from "./page/HOC/MyProtectedComponent";

function App() {
    return (
        <div className="App">
            ......
            <div className="App-item">
                测试高阶组件:<MyProtectedComponent />
            </div>
        </div>
    );
}

export default App;

在这里插入图片描述

withAuthentication是一个HOC,它接收一个组件作为参数,并返回一个新的组件,该组件在渲染时会检查isAuthorized属性来决定是否显示被包裹的组件。MyProtectedComponent是一个简单的组件,用作演示如何使用这个HOC来控制访问权限。最后,在App组件中,通过<ProtectedComponent isAuthorized={true} />来使用这个受保护的组件,并明确指定了isAuthorizedtrue来允许渲染。可以根据实际情况调整isAuthorized的值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1838524.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Zyxel NAS设备 setCookie 未授权命令注入漏洞复现(CVE-2024-29973)

0x01 产品简介 Zyxel-NAS 是指由 Zyxel Communications Corporation(合勤科技股份有限公司)开发和生产的网络附加存储(Network Attached Storage,简称 NAS)设备。NAS 是一种专门用于存储和共享文件的设备,它通过网络连接到计算机、服务器或其他设备,提供集中式的文件存…

linux最大线程数限制及打开最大文件数

1.root用户下执行 ulimit -a 然后查看 max user processes 这个值通常是系统最大线程数的一半 max user processes&#xff1a;当前用户同时打开的进程(包括线程)的最大个数为 2.普通用户下 ulimit -a 出现的max user processes的值 默认是 /etc/security/limits.d/20-nproc.co…

范式(下)-BC范式(BCNF)、关系模式的规范化

一、关系模式STC 假设有一个关系模式STC&#xff0c;包含有学号Sno、教师编号Tno、课程编号Cno、选课成绩G四个属性 即STC(Sno&#xff0c;Tno&#xff0c;Cno&#xff0c;G) 数据间的关系为 每个学生可选修多门课程&#xff0c;每门课程可以被多名学生选修每个老师只能讲授…

虹科免拆诊断案例 | 15款马自达3偶发高速CAN网络故障

CAN总线大家都不陌生&#xff0c;遇到这类故障&#xff0c;我们第一反应可能是用万用表测一下电压&#xff0c;看看存不存在短路、断路等问题。不过&#xff0c;使用万用表测得的电压值只是CAN总线上的平均电压&#xff0c;是一个大概的数值&#xff0c;并不能反映真实的CAN总线…

用户组相关的一些命令

1./etc/passwd>列出了系统里的所有用户 2./etc/shadow>保存了用户的密码信息 空表示密码为空 *表示账号被在锁定 !表示未设置密码 !!表示这个密码已经过期 $1表示MD5加密&#xff0c; $2表示用Blowfish加密&#xff0c; $5表示用SHA-256加密&#xff0c; $6表示SHA-512加…

关于微信小程序(必看)

前言 为规范开发者的用户个人信息处理行为&#xff0c;保障用户的合法权益&#xff0c;自2023年9月15日起&#xff0c;对于涉及处理用户个人信息的小程序开发者&#xff0c;微信要求&#xff0c;仅当开发者主动向平台同步用户已阅读并同意了小程序的隐私保护指引等信息处理规则…

FANUC喷涂机器人P-350iA电机过热维修解决方案

发那科喷涂机器人作为自动化喷涂生产线的重要组成部分&#xff0c;其性能稳定性和可靠性对于生产效率和产品质量具有重要影响。然而&#xff0c;在实际使用过程中&#xff0c;FANUC喷涂机器人P-350iA电机过热故障问题往往成为影响其正常运行的主要因素之一。 FANUC机器人M-100…

数据库实战(一)(关系数据库设计)

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;数据库 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 前言 练习题 题型一&#xff1a;判断关系…

登录爆破神器:Hydra 保姆级教程

前言 Hydra 是一个广泛使用的网络登录破解工具&#xff0c;支持多种协议&#xff08;如 HTTP、FTP、SSH、Telnet 等&#xff09;&#xff0c;用于执行暴力破解攻击。它由 Van Hauser 和 The Hackers Choice (THC) 团队开发&#xff0c;设计用于快速和高效地尝试大量用户名和密…

信息技术课如何禁止学生玩游戏

在信息技术课上禁止学生玩游戏是一个常见的挑战&#xff0c;但可以通过一系列策略和工具来有效地实现。以下是一些建议&#xff1a; 明确课堂规则和纪律&#xff1a; (1)在课程开始时&#xff0c;明确告知学生课堂规则和纪律&#xff0c;包括禁止玩游戏的规定。 (2)强调遵守…

创建一个electron桌面备忘录

Sound Of Silence 1.创建electron项目命令&#xff1a; npm create quick-start/electron my-new-project 2选择&#xff1a;√ Select a framework: vue √ Add TypeScript? ... No √ Add Electron updater plugin? ... Yes √ Enable Electron download mirror proxy? .…

记一次生产事故,来来回回搞了一个月

&#x1f345;我是小宋&#xff0c;关注我&#xff0c;带你轻松过面试 读源码。提升简历亮点&#xff08;14个demo&#xff09; &#x1f30f;号&#xff1a;tutou123com。拉你进专属群。 记一次生产事故&#xff0c;来来回回搞了一个月 背景 我们的主要业务是台湾省的一个小…

工业自动化中OBC充电机测试负载箱的应用

在工业自动化中&#xff0c;OBC充电机是电动汽车和混合动力汽车的重要组成部分。它的主要功能是为电动汽车的电池组提供电能&#xff0c;保证车辆的正常运行。为了保证OBC充电机的性能和安全性&#xff0c;通常需要对其进行严格的测试。在这个过程中&#xff0c;负载箱是一种非…

【SQL server速成之路】函数

&#xff08;3&#xff09;LEFT函数 LEFT ( character_expression , integer_expression ) 功能&#xff1a;返回从字符串character_expression左边开始&#xff0c;由integer_expression指定个数的字符。参数character_expression&#xff1a;为字符型表达式&#xff0c;integ…

C#的Switch语句2(如何快速中断函数执行)

文章目录 switch语法结构case具体的值枚举值字符串const关键字 如果没有匹配的值default语句不一定要在最后与C的差异-case穿透&#xff08;Fall-through&#xff09; 下一篇文章 switch语法结构 基础的语法结构&#xff0c;在上一篇文章已经写了&#xff0c;具体请看&#xf…

Python --- 如何修改Jupyter Notebook在本地保存文件的默认路径?

如何修改Jupyter Notebook在本地保存文件的默认路径&#xff1f; 一直以来都比较喜欢jupter notebook&#xff0c;自从用了以后就爱上了。平时用的时候&#xff0c;因为大多都是临时调用&#xff0c;每次在界面里直接new一个新的file就开干。 曾经也想过我创建的这些python文件…

MySQL从5.7升级到8.0步骤及其问题

MySQL从5.7升级到8.0步骤及其问题 前言 本文源自微博客&#xff0c;且以获得授权&#xff0c;请尊重版权。 一、需求背景 Docker环境下&#xff0c;MySQL5.7升级到8.0&#xff0c;数据迁移时使用的是mysqldump方式迁移。 二、迁移步骤 数据备份&#xff1a; docker exec -i 1…

QEMU + Vscode + Arm Arch‘s Linux调试小记

目录 下载QEMU 下载aarch64-gcc 下载BusyBox 编译linux 6.9.5的内核 启动&#xff01; 链接到vscode进行远程调试 Reference 前几天看到了一篇讲授如何调试ARM Linux内核的文章&#xff0c;这里现在记录一下调试ARM Linux内核的办法 下载QEMU 对于Arch Linux用户而言&a…

结构思考力:让你的思维更有条理

在这个信息爆炸的时代&#xff0c;如何让自己的思维更有条理&#xff0c;更高效地沟通显得尤为重要。最近读了《结构思考力》一书。今天&#xff0c;我想和大家分享一下读后感&#xff0c;从以下几个方面展开&#xff1a;1. 什么是结构思考力及其重要性&#xff1b;2. 为什么要…

数据治理创新路:建设数据集市,强化数据报送一致性新实践

随着信息化和数字化的飞速发展&#xff0c;数据已经成为企业运营和决策的核心要素。然而&#xff0c;数据治理的复杂性和多样性给企业带来了不小的挑战。为了更好地应对这些挑战&#xff0c;许多企业开始探索数据治理的创新路径&#xff0c;其中建设数据集市和强化数据报送一致…