当前位置: 首页 > article >正文

react 类组件和函数组件区别

  1. 类组件需要使用this关键字来访问props和状态,而函数组件则可以直接访问这些值。
  2. 原来只有类组件可以使用的特性,比如状态和生命周期方法,现在函数组件通过Hooks也可以使用。
  3. 函数组件通常更简洁,更易于测试和理解。
  4. 类组件目前仍然支持一些尚未在函数组件中提供的特性,比如错误边界。

  1. 语法上:“函数组件是一个纯函数,它接收一个 props 对象返回一个 react 元素; 类组件需要去继承 React.Component 并且创建 render 函数返回 react 元素,虽然实现的效果相同,但需要更多的代码。”

类是组合寄生继承的语法糖,如果我们需要转译成 ES5 之前的代码,我们需要更多的预置代码,从而导致体积更大。

  1. 功能上:“之前,在使用场景上,如果存在需要使用生命周期的组件,那么主推类组件;设计模式上,如果需要继承,也是类组件。但现在由于 React hooks 的推出,生命周期概念的淡出,函数组件完全可以取代类组件。其次继承也不是组件最佳的设计模式,官方更推崇“组合优先于继承”的设计概念,所以类组件在这方面的优势也在淡出。”

  2. 类组件在未来事件切片与并发模式中,由于生命周期带来的复杂度,并不易于优化。而函数组件本身轻量简单,且在 Hooks 的基础上提供了比原先更细粒度的逻辑组织与复用,更能使用 React 的未来发展。


http://www.kler.cn/a/390779.html

相关文章:

  • request爬虫库的小坑
  • 常用的Anaconda Prompt命令行指令
  • 网页版五子棋——对战模块(服务器端开发②)
  • 【日志】392.判断子序列
  • 笔记 | image may have poor performance,or fail,if run via emulation
  • 中文书籍对《人月神话》的引用(161-210本):微软的秘密
  • 【系统架构设计师】真题论文: 论数据挖掘技术的应用(包括解题思路和素材)
  • 一些npm总结(持续更新...)
  • pwn学习笔记(12)--Chunk Extend and Overlapping
  • 羊城杯2020Easyphp
  • 如何使用 VNC 服务器连接桌面
  • 新的恶意软件活动通过游戏应用程序瞄准 Windows 用户
  • kafka+zookeeper的搭建
  • Mysql个人八股总结
  • 置信传播算法复现
  • idea 基础简单应用(java)
  • BY组态-低代码web可视化组件
  • Android Studio 学习——整体框架和概念
  • kafka消费者出现频繁Rebalance
  • 使用Docker-compose安装mysql5.7
  • 29.电影院售票系统(基于springboot和vue的Java项目)
  • 【go从零单排】sorting排序、Sorting by Functions排序方法
  • DPI-MoCo:基于深度先验图像约束的运动补偿重建用于四维锥形束CT (4D CBCT)|文献速递-基于深度学习的病灶分割与数据超分辨率
  • Android Glide动态apply centerCropTransform(),transition withCrossFade动画,Kotlin
  • 【LeetCode】【算法】5. 最长回文子串
  • docker——项目部署