【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…...
springboot 百货中心供应链管理系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,百货中心供应链管理系统被用户普遍使用,为方…...
23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...
为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...
家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
Frozen-Flask :将 Flask 应用“冻结”为静态文件
Frozen-Flask 是一个用于将 Flask 应用“冻结”为静态文件的 Python 扩展。它的核心用途是:将一个 Flask Web 应用生成成纯静态 HTML 文件,从而可以部署到静态网站托管服务上,如 GitHub Pages、Netlify 或任何支持静态文件的网站服务器。 &am…...
P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...
SpringTask-03.入门案例
一.入门案例 启动类: package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...
