【React】组件:全面解析现代前端开发的基石
文章目录
- 一、什么是组件?
- 二、组件的类型
- 三、组件的生命周期
- 四、状态管理
- 五、属性传递
- 六、组合与继承
- 七、最佳实践
在现代前端开发中,React 已成为开发者构建用户界面的首选框架之一。React 的强大之处在于其组件化设计,允许开发者将 UI 拆分为独立、可复用的组件。本文将详细介绍 React 中的组件,包括组件的定义、类型、生命周期、状态管理、属性传递以及最佳实践,帮助开发者深入理解和高效使用 React 组件。
一、什么是组件?
组件是 React 的基本构建块。每个组件都可以看作是一个独立的模块,负责实现界面中的一部分。组件可以嵌套使用,从而构建出复杂的用户界面。组件的设计理念是将 UI 和业务逻辑分离,使代码更加模块化和易于维护。一个组件就是首字母大写的函数。
二、组件的类型
React 中的组件主要分为两种类型:函数组件和类组件。
-
函数组件
函数组件是定义组件的最简单方式。它们本质上是接收 props 并返回 JSX 的普通 JavaScript 函数。自 React 16.8 引入 Hooks 以来,函数组件变得更加强大,可以处理状态和副作用。
function Greeting(props) {return <h1>你好, {props.name}</h1>; }
-
类组件
类组件是通过 ES6 类语法定义的组件,具有更多的特性,如状态管理和生命周期方法。在 Hooks 引入之前,类组件是实现复杂组件逻辑的主要方式。
class Greeting extends React.Component {render() {return <h1>你好, {this.props.name}</h1>;} }
三、组件的生命周期
类组件具有生命周期方法,可以在组件的不同阶段执行特定的操作。React 的组件生命周期分为三个主要阶段:挂载、更新和卸载。
- 挂载阶段
constructor()
: 构造函数,在组件实例化时调用。static getDerivedStateFromProps()
: 每次在组件实例被重新渲染之前调用。componentDidMount()
: 在组件挂载到 DOM 后调用,可以在这里进行 DOM 操作或数据请求。
- 更新阶段
shouldComponentUpdate()
: 在重新渲染前调用,可以根据条件决定是否重新渲染组件。getSnapshotBeforeUpdate()
: 在最新的渲染输出提交到 DOM 之前调用,可以捕获一些信息。componentDidUpdate()
: 在组件更新后调用,可以在这里进行 DOM 操作或数据请求。
- 卸载阶段
componentWillUnmount()
: 在组件从 DOM 中移除之前调用,可以在这里执行清理操作,如取消定时器或网络请求。
四、状态管理
组件的状态(state)是指组件中需要动态变化的数据。类组件使用 this.state
初始化状态,并使用 this.setState()
方法更新状态。函数组件使用 useState
Hook 来管理状态。
-
类组件中的状态管理
class Counter extends React.Component {constructor(props) {super(props);this.state = { count: 0 };}increment = () => {this.setState({ count: this.state.count + 1 });}render() {return (<div><p>计数: {this.state.count}</p><button onClick={this.increment}>增加</button></div>);} }
-
函数组件中的状态管理
function Counter() {const [count, setCount] = React.useState(0);return (<div><p>计数: {count}</p><button onClick={() => setCount(count + 1)}>增加</button></div>); }
五、属性传递
组件通过 props 接收从父组件传递的数据。props 是只读的,不能在子组件中修改。通过 props,组件可以实现数据的传递和复用。
-
基本属性传递
function Greeting(props) {return <h1>你好, {props.name}</h1>; }function App() {return <Greeting name="世界" />; }
-
传递回调函数
可以通过 props 传递回调函数,以实现父子组件之间的通信。
class Parent extends React.Component {handleChildClick = () => {console.log('子组件按钮被点击了');}render() {return <Child onClick={this.handleChildClick} />;} }function Child(props) {return <button onClick={props.onClick}>点击我</button>; }
六、组合与继承
React 提倡使用组合而非继承来复用组件逻辑。组合可以通过将子组件作为 props 传递给父组件,或使用 React 提供的 children
属性。
-
包含关系
包含关系是指一个组件包含另一个组件,通过
children
属性传递子组件。function Container(props) {return <div className="container">{props.children}</div>; }function App() {return (<Container><h1>标题</h1><p>这是内容。</p></Container>); }
-
特殊化关系
特殊化关系是指一个组件通过 props 定制另一个组件,以实现特定的功能。
function Dialog(props) {return (<div className="dialog"><h1>{props.title}</h1><p>{props.message}</p></div>); }function WelcomeDialog() {return <Dialog title="欢迎" message="欢迎使用我们的应用!" />; }
七、最佳实践
-
保持组件的单一职责
每个组件应只负责一个功能。通过将功能拆分为多个小组件,可以提高代码的可读性和可维护性。
-
使用函数组件和 Hooks
优先使用函数组件和 Hooks 来管理状态和副作用,除非需要使用生命周期方法或有复杂的逻辑需要封装。
-
使用 PropTypes 检查
使用
PropTypes
来进行类型检查,可以在开发过程中捕获类型错误,提高代码的可靠性。import PropTypes from 'prop-types';function Greeting(props) {return <h1>你好, {props.name}</h1>; }Greeting.propTypes = {name: PropTypes.string.isRequired };
-
保持组件的纯净
尽量编写纯函数组件,避免在渲染过程中引入副作用。所有的副作用操作(如数据请求、订阅等)应放在
useEffect
或生命周期方法中。
相关文章:

【React】组件:全面解析现代前端开发的基石
文章目录 一、什么是组件?二、组件的类型三、组件的生命周期四、状态管理五、属性传递六、组合与继承七、最佳实践 在现代前端开发中,React 已成为开发者构建用户界面的首选框架之一。React 的强大之处在于其组件化设计,允许开发者将 UI 拆分…...

java学习--包装类
包装类 Boolean的关系图 Character关系图 其他关系图 包装类和基本数据转换 Debug进入之后可以看到底层代码如下 例题: 三元运算符是一个整体返回的数的类型看其中所含类型最高的那个是谁就会转成哪个 想要掌握这个这个知识,就要多看源码,直接…...

Python Django功能强大的扩展库之channels使用详解
概要 随着实时 web 应用程序的兴起,传统的同步 web 框架已经无法满足高并发和实时通信的需求。Django Channels 是 Django 的一个扩展,旨在将 Django 从一个同步 HTTP 框架转变为一个支持 WebSockets、HTTP2 和其他协议的异步框架。它不仅能够处理传统的 HTTP 请求,还可以处…...

推荐3款将相片变为动漫风格的免费AI工具推荐
toonme ToonMe是一款功能强大的在线和移动端应用,专门用于将照片转换成卡通风格图像。该工具利用先进的AI技术,能够快速识别照片中的面部特征,并进行智能处理,生成高清晰度的卡通肖像。 功能特点 ToonMe通过其内置的人工智能算法…...
【职业学习】高效工作法
文章目录 01 时间拳击02 非同步沟通03 批量处理04. 80/20法则05. 一次只做一件事 01 时间拳击 时间拳击(Time Boxing)核心是给每项任务创造一个时间限制,然后在固定的时间段内专注地完成这个任务。 不同于传统的待办事项清单:8点…...

【iOS】Tagged Pointer
目录 前言什么是Tagged Pointer?引入Tagged Pointer技术之前引入Tagged Pointer之后总结 Tagged Pointer原理(TagData分析)关闭数据混淆MacOS分析NSNumberNSString iOS分析 判断Tagged PointerTagged Pointer应用Tagged Pointer 注意点 Tagge…...

Mysql explain 优化解析
explain 解释 select_type 效率对比 MySQL 中 EXPLAIN 语句的 select_type 列描述了查询的类型,不同的 select_type 类型在效率上会有所差异。下面我们来比较一下各种 select_type 的效率: SIMPLE: 这是最简单的查询类型,表示查询不包含子查询或 UNION 操作。 这种查询通常是…...

wget下载github文件得到html文件
从github/gitee下载源文件,本来是22M下载下来只有11k 原因: Github会提供html页面,包括指定的文件、上下文与相关操作。通过wget或者curl下载时,会下载该页面 解决方式: github点击Code一栏的raw按钮,获得源…...

【es】elasticsearch 自定义排序-按关键字位置排序
一 背景 要求es查询的结果按关键字位置排序,位置越靠前优先级越高。 es版本7.14.0,项目是thrift,也可以平替springboot,使用easyes连接es。 二 easyes使用 配easyes按官方文档就差不多了 排序 | Easy-Es 主要的一个问题是easy…...
堆的相关知识点
目录 大小堆 堆的实现 堆的创建 堆的销毁 交换 向上调整 向下调整 弹出首个元素 取出首个元素 判空 堆插入 大小堆 大堆:最上面的数字是最小的,越往下越大 小堆:最上面的数字是最大的,越往下越小 堆的复杂程度&#…...
【Sass】常用全局sass高级函数,可使用原子化CSS减轻代码量,方便快速开发
文章目录 前言一、安装二、样式custom.scssflex.scsscolor.scssmargin-padding.scssorther 总结 前言 提示:这里可以添加本文要记录的大概内容: 针对style的预编译器为scss 转载自git前端知识库 原博主是B站up程序员郑清,可以看他的v3教程…...

MYSQL 第四次作业
任务要求: 具体操作: 新建数据库: mysql> CREATE DATABASE mydb15_indexstu; Query OK, 1 row affected (0.01 sec) mysql> USE mydb15_indexstu; Database changed 新建表: mysql> CREATE TABLE student( ->…...

depcheck 前端依赖检查
介绍 depcheck 是一款用于检测项目中 未使用依赖项 的工具。 depcheck 通过扫描项目文件,帮助你找出未被引用的依赖,从而优化项目。 优势: 简单易用: 仅需几个简单的命令,就能够扫描并列出未使用的依赖项,让你快速了…...
Qt/C++音视频开发79-采集websocket视频流/打开ws开头的地址/音视频同步/保存到MP4文件/视频回放
一、前言 随着音视频的爆发式的增长,各种推拉流应用场景应运而生,基本上都要求各个端都能查看实时视频流,比如PC端、手机端、网页端,在网页端用websocket来接收并解码实时视频流显示,是一个非常常规的场景,单纯的http-flv模式受限于最大6个通道同时显示,一般会选择ws-f…...
网络安全等级保护制度1.0与2.0的演进与变革
等保1.0概述 等保1.0是我国在网络安全领域迈出的重要一步,它于2008年正式发布。该版本的等保制度以《信息安全技术 信息系统安全等级保护基本要求》为核心标准,主要聚焦于信息系统的物理安全、网络安全、主机安全、应用安全和数据安全等方面的基础防护。…...

多线程优化API请求:CountDownLatch与PriorityBlockingQueue的应用
目录 前言 CountDownLatch是什么? PriorityBlockingQueue是什么? 场景描述 解决方案 定义统一工厂制造类 定义制造厂 定义客户请求实现 定义控制器 定义启动类 结果呈现 启动项目 请求制造操作 总结 前言 写这篇文章的缘由是因为之前在面…...

谷粒商城实战笔记-54-商品服务-API-三级分类-拖拽效果
文章目录 一,54-商品服务-API-三级分类-修改-拖拽效果1,el-tree控件加上允许拖拽的属性2,是否允许拖拽3,完整代码 一,54-商品服务-API-三级分类-修改-拖拽效果 本节的主要内容是给三级分类树形结构加上拖拽功能&#…...
AI大模型学习必备十大网站
随着人工智能技术的快速发展,AI大模型(如GPT-3、BERT等)在自然语言处理、计算机视觉等领域取得了显著的成果。对于希望深入学习AI大模型的开发者和研究者来说,找到合适的学习资源至关重要。本文将为大家推荐十大必备网站ÿ…...

Elasticsearch:Golang ECS 日志记录 - zap
ECS 记录器是你最喜欢的日志库的格式化程序/编码器插件。它们可让你轻松地将日志格式化为与 ECS 兼容的 JSON。 编码器以 JSON 格式记录日志,并在可能的情况下依赖默认的 zapcore/json_encoder。它还处理 ECS 错误格式的错误字段记录。 默认情况下,会添…...
关于线性代数(考研)
1.AE的特征值的问题 若λ是A的特征值,对应的特征向量是x,则Axλx,所以(AE)xAxExλxx(λ1)x,所以λ1是AE的特征值。所以若A的特征值是1,1,0,则AE的特征值就是11,11,01&am…...

Xshell远程连接Kali(默认 | 私钥)Note版
前言:xshell远程连接,私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...
C++.OpenGL (10/64)基础光照(Basic Lighting)
基础光照(Basic Lighting) 冯氏光照模型(Phong Lighting Model) #mermaid-svg-GLdskXwWINxNGHso {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-GLdskXwWINxNGHso .error-icon{fill:#552222;}#mermaid-svg-GLd…...

基于Java+MySQL实现(GUI)客户管理系统
客户资料管理系统的设计与实现 第一章 需求分析 1.1 需求总体介绍 本项目为了方便维护客户信息为了方便维护客户信息,对客户进行统一管理,可以把所有客户信息录入系统,进行维护和统计功能。可通过文件的方式保存相关录入数据,对…...
【Elasticsearch】Elasticsearch 在大数据生态圈的地位 实践经验
Elasticsearch 在大数据生态圈的地位 & 实践经验 1.Elasticsearch 的优势1.1 Elasticsearch 解决的核心问题1.1.1 传统方案的短板1.1.2 Elasticsearch 的解决方案 1.2 与大数据组件的对比优势1.3 关键优势技术支撑1.4 Elasticsearch 的竞品1.4.1 全文搜索领域1.4.2 日志分析…...

DBLP数据库是什么?
DBLP(Digital Bibliography & Library Project)Computer Science Bibliography是全球著名的计算机科学出版物的开放书目数据库。DBLP所收录的期刊和会议论文质量较高,数据库文献更新速度很快,很好地反映了国际计算机科学学术研…...

【无标题】湖北理元理律师事务所:债务优化中的生活保障与法律平衡之道
文/法律实务观察组 在债务重组领域,专业机构的核心价值不仅在于减轻债务数字,更在于帮助债务人在履行义务的同时维持基本生活尊严。湖北理元理律师事务所的服务实践表明,合法债务优化需同步实现三重平衡: 法律刚性(债…...
前端高频面试题2:浏览器/计算机网络
本专栏相关链接 前端高频面试题1:HTML/CSS 前端高频面试题2:浏览器/计算机网络 前端高频面试题3:JavaScript 1.什么是强缓存、协商缓存? 强缓存: 当浏览器请求资源时,首先检查本地缓存是否命中。如果命…...

热门Chrome扩展程序存在明文传输风险,用户隐私安全受威胁
赛门铁克威胁猎手团队最新报告披露,数款拥有数百万活跃用户的Chrome扩展程序正在通过未加密的HTTP连接静默泄露用户敏感数据,严重威胁用户隐私安全。 知名扩展程序存在明文传输风险 尽管宣称提供安全浏览、数据分析或便捷界面等功能,但SEMR…...
JS红宝书笔记 - 3.3 变量
要定义变量,可以使用var操作符,后跟变量名 ES实现变量初始化,因此可以同时定义变量并设置它的值 使用var操作符定义的变量会成为包含它的函数的局部变量。 在函数内定义变量时省略var操作符,可以创建一个全局变量 如果需要定义…...

【PX4飞控】mavros gps相关话题分析,经纬度海拔获取方法,卫星数锁定状态获取方法
使用 ROS1-Noetic 和 mavros v1.20.1, 携带经纬度海拔的话题主要有三个: /mavros/global_position/raw/fix/mavros/gpsstatus/gps1/raw/mavros/global_position/global 查看 mavros 源码,来分析他们的发布过程。发现前两个话题都对应了同一…...