【react】类组件和函数组件的区别

目录

类组件和函数组件的区别

1. 定义方式

2. 状态管理

3. 生命周期方法

4. 性能优化

5. 语法简洁性

6. Hooks 的使用

总结


函数组件和类组件是 React 中两种主要的组件形式

类组件和函数组件的区别

1. 定义方式

函数组件:使用函数定义,通常以 constfunction 开头。

const MyFunctionComponent = (props) => {return <div>{props.message}</div>;
};

类组件:使用 ES6 类定义,继承自 React.Component

class MyClassComponent extends React.Component {render() {return <div>{this.props.message}</div>;}
}

2. 状态管理

函数组件

在 React Hooks 出现之前,函数组件是无状态的,不能直接管理状态。但现在可以通过 useState Hook 管理状态。

类组件

类组件可以有自己的状态,通过 this.state 来管理。

class MyClassComponent extends React.Component {constructor(props) {super(props);this.state = { count: 0 };}render() {return <div>Count: {this.state.count}</div>;}
}

3. 生命周期方法

函数组件:没有生命周期方法,但现在可以通过 useEffect Hook 来实现类似的功能。

const MyFunctionComponent = () => {useEffect(() => {console.log('Component mounted');return () => console.log('Component unmounted');}, []);return <div>My Function Component</div>;
};

类组件:有完整的生命周期方法,如 componentDidMountcomponentDidUpdatecomponentWillUnmount 等。

class MyClassComponent extends React.Component {componentDidMount() {console.log('Component mounted');}componentWillUnmount() {console.log('Component unmounted');}render() {return <div>My Class Component</div>;}
}

//函数组件
const MyFunctionComponent = (props) => {const [state, setState] = useState({loading:true,data: [],model:props.model || '',});//类组件
class MyFunctionComponent extends React.Component {constructor(props) {super(props);this.state = {loading: true,model: props.model || '',}}//函数组件useEffect(() => {if (props.model) {setState((prevState) => ({...prevState,model: props.model,}));}sync();}, [props.model, props.data]);const sync = () => {const { data } = props;const wrappedData = wrapDataNew(data);setState((prevState) => ({...prevState,loading: false,...wrappedData,}));};
//类组件componentDidMount() {const { model } = this.props;if (model) this.setState({ model });this.sync();}sync = () => {const { data } = this.props;let wrappedData = this.wrapDataNew(data);this.setState({ loading: false, ...wrappedData });};render(){return
}};

 以上为举例区别函数组件和类组件的写作方式,实际无意义 

4. 性能优化

函数组件

可以使用 React.memo 进行性能优化,避免不必要的重渲染。

const MyFunctionComponent = React.memo((props) => {return <div>{props.value}</div>;
});
类组件

可以使用 shouldComponentUpdate 方法来控制组件是否更新。

class MyClassComponent extends React.Component {shouldComponentUpdate(nextProps, nextState) {return nextProps.value !== this.props.value;}render() {return <div>{this.props.value}</div>;}
}

5. 语法简洁性

函数组件:语法更简洁,尤其是使用 Hooks 后,代码更易于阅读和维护。

类组件:语法相对复杂,需要更多的样板代码。

6. Hooks 的使用

函数组件:可以使用 Hooks 来管理状态和副作用,使函数组件的功能更强大。

类组件:不能使用 Hooks,因为 Hooks 是为函数组件设计的。

总结

函数组件:语法简洁,适合大多数场景,尤其是使用 Hooks 后,功能已经非常强大。

类组件:适合需要复杂生命周期管理的场景,但在新项目中逐渐被函数组件和 Hooks 替代。

在实际开发中,建议优先使用函数组件和 Hooks,因为它们更简洁且功能强大。类组件仍然在一些特定场景下有用,但新功能开发通常推荐使用函数组件

码字不易,各位大佬点点赞呗

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2.pycharm部署Ai - 编程好助手

一、pycharm安装continue插件 1.提前安装好pycharm&#xff0c;并双击打开 2.File – Setting 3.Plugins – 搜索Continue &#xff0c; 点击Install安装 4.点ok 二、获取硅基流动API 1.登入网站&#xff1a;https://siliconflow.cn/zh-cn/#/&#xff0c;并注册登入 2.获取AP…

《数据结构:单链表》

“希望就像星星&#xff0c;或许光芒微弱&#xff0c;但永不熄灭。” 博主的个人gitee&#xff1a;https://gitee.com/friend-a188881041351 一.概念与结构 链表是一种物理存储上非连续、非顺序的存储结构&#xff0c;数据元素的顺序逻辑是通过链表中的指针链接次序实现的。 单…

Visual Studio 2019 Qt QML 项目环境搭建常见问题处理方法

在 Visual Studio 2019 运行 Qt/QML 项目比直接使用QtCreator环境麻烦&#xff0c;主要是有qmake 的一些配置项不能在 Visual Studio中设置。下面整理一些常见问题的处理方法&#xff0c;供参考&#xff1a; 搭建VS Qt 环境&#xff0c;在Visual Studios 2019下面安装 Qt Vis…

基于Spring Boot的网上商城系统的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

如何监控和优化服务器的 CPU 性能

一、实时监控与诊断工具 1. 核心监控工具 bash 复制 # 实时CPU使用率监控 top -H -p <PID> # 按线程查看CPU占用 htop --sort-keyPERCENT_CPU # 可视化进程CPU排序 mpstat -P ALL 1 # 每核心使用率统计 2. 上下文切换分析 bash 复制 pidstat -w…

【蓝桥杯14天冲刺课题单】Day 1

1. 题目链接&#xff1a;19937 艺术与篮球 该题目的难点主要在20240413这个日期需要结束程序跳出循环。最开始将该输出ans的位置放在了for循环之外&#xff0c;此时的日期已经循环完了2024年所有的日期&#xff0c;则最后会统计多而导致结果错误。 AC代码&#xff1a; #incl…

Masked Attention 在 LLM 训练中的作用与原理

在大语言模型&#xff08;LLM&#xff09;训练过程中&#xff0c;Masked Attention&#xff08;掩码注意力&#xff09; 是一个关键机制&#xff0c;它决定了 模型如何在训练时只利用过去的信息&#xff0c;而不会看到未来的 token。这篇文章将帮助你理解 Masked Attention 的作…

Arduino、ESP32驱动GUVA-S12SD UV紫外线传感器(光照传感器篇)

目录 1、传感器特性 2、控制器和传感器连线图 3、驱动程序 UV紫外线传感器是一个测试紫外线总量的最佳传感器,它不需要使用波长滤波器,只对紫外线敏感。 Arduino UV紫外线传感器,直接输出对应紫外线指数(UV INDEX)的线性电压,输出电压范围大约0~1100mV(对应UV INDEX值…

基于微波光子信道的图像传输系统matlab仿真,调制方式采用OFDM+QPSK,LDPC编译码以及LS信道估计

目录 1.算法仿真效果 2.算法涉及理论知识概要 2.1 OFDMQPSK原理 2.2 微波光子信道简介 3.MATLAB核心程序 4.完整算法代码文件获得 1.算法仿真效果 matlab2022a仿真结果如下&#xff08;完整代码运行后无水印&#xff09;&#xff1a; 仿真操作步骤可参考程序配套的操作视…

【黑马点评】Redis解决集群的session共享问题

由于不同的tomcat服务器之间的session是不共享的&#xff0c;当请求如果在不同tomcat服务器之间切换就会导致数据丢失的问题。 使用redis可以解决session数据共享的问题 redis是tomcat以外的存储&#xff0c;存在redis中的数据&#xff0c;任何一台tomcat都能看得见&#xff0…

淘宝客户端动态化页面搭建

在手机淘宝等高频更新的业务场景中&#xff0c;UI页面的动态化和快速交付成为技术团队面临的重要挑战。本文围绕“客户端动态化页面搭建”这一主题&#xff0c;深入探讨了如何通过抽象框架设计解决高动态化页面的快速构建问题。文章详细介绍了框架的核心模块&#xff08;如Data…

无人机,雷达定点飞行时,位置发散,位置很飘,原因分析

参考&#xff1a; 无人车传感器 IMU与GPS数据融合进行定位机制_gps imu 组合定位原始数-CSDN博客 我的无人机使用雷达定位&#xff0c;位置模式很飘 雷达的更新频率也是10HZ&#xff0c; 而px飞控的频率是100HZ&#xff0c;没有对两者之间的频率差异做出处理 所以才导致无人…

Postman 版本信息速查:快速定位版本号

保持 Postman 更新至最新版本是非常重要的&#xff0c;因为这能让我们享受到最新的功能&#xff0c;同时也保证了软件的安全性。所以&#xff0c;如何快速查看你的 Postman 版本信息呢&#xff1f; 如何查看 Postman 的版本信息教程

Object结构

Object结构 参考博客

数据分析概述

数据分析&#xff1a;用适当的分析方法和挖掘方法对收集来的数据进行研究总结&#xff0c;提取有用的信息&#xff0c;形成结论并支持决策的过程。 一.数据分析的分类 1.业务描述性分析。以数据为分析对象&#xff0c;以探索数据内的有用信息为主要途径&#xff0c;以解决业务…

ubuntu下终端打不开的排查思路和解决方法

问题现象描述&#xff1a;ubuntu开机后系统桌面显示正常&#xff0c;其他图形化的app也都能打开无异常&#xff0c;唯独只有terminal终端打不开&#xff0c;无论是鼠标点击终端软件&#xff0c;还是ctrlaltt&#xff0c;还是altF2后输入gnome-terminal后按回车&#xff0c;这三…

第一天 Linux驱动程序简介

目录 一、驱动的作用 二、裸机驱动 VS linux驱动 1、裸机驱动 2、linux驱动 三、linux驱动位于哪里&#xff1f; 四、应用编程 VS 内核编程 1、共同点 2、不同点 五、linux驱动分类 1、字符设备 2、块设备 3、网络设备 六、Linux驱动学习难点与误区 1、学习难点 …

探索抓包利器ProxyPin,实现手机APP请求抓包,支持https请求

以下是ProxyPin的简单介绍&#xff1a; - ProxyPin是一个开源免费HTTP(S)流量捕获神器&#xff0c;支持 Windows、Mac、Android、IOS、Linux 全平台系统- 可以使用它来拦截、检查并重写HTTP(S)流量&#xff0c;支持捕获各种应用的网络请求。ProxyPin基于Flutter开发&#xff0…

Windows中安装git工具

下载好git安装包 点击next 选择安装目录 根据需要去勾选 点击next 点击next PATH环境选择第二个【Git...software】即可&#xff0c;再点击【Next】。 第一种配置是“仅从Git Bash使用Git”。这是最安全的选择&#xff0c;因为您的PATH根本不会被修改。您只能使用 Git Bash 的…

Banner区域

div下 justify-content:space-between 左侧测导航left 在这里插入图片描述 在这里插入图片描述