浅谈memo、PureComponent、useMemo、useEffect、useCallback的区别

2024-06-04 19:04

本文主要是介绍浅谈memo、PureComponent、useMemo、useEffect、useCallback的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、memo()与PureComponent类组件的区别
  • 二、memo()与useMemo()的区别
  • 三、useMemo() 和 useEffect() 的区别
  • 四、useMemo() 和 useCallback() 的区别


前言

在现在的react开发中,我们经常会使用的一些比较型的hook,都是为了提升性能,起到优化的目的。但是不能为了用而用,这东西不是用的越多越好,要视情况而定。下面讲几个常用的,并对比之间的区别。

一、memo()与PureComponent类组件的区别

(1)memo()是后面hook时代推出的,等同于class component时代的PureComponent类组件,但有差别。memo()不传参数时,和PureComponent类组件效果一样,都是浅比较
(2)当传入参数时,memo()可进行深度比较,可利用第二个参数传参。在class 时代时,也可利用shouldComponentUpdate()进行深度比较。现在提倡用memo(),使用起来更方便

二、memo()与useMemo()的区别

(1)React.memo()针对的是整个组件间的状态比较
(2)假如我们只想组件的某个部分HTML代码不进行re-render,这时候就要使用useMemo()进行针对性比较,它接收一个依赖数组,只有当数组检测到变化时,才会进行re-render

三、useMemo() 和 useEffect() 的区别

(1)useMemo()是在渲染期间执行的,不能执行一些额外副操作,否则会造成死循环,反复操作dom元素,导致浏览器卡死。比如网络请求,setState等
(2)如果要执行一些"副作用"操作,就得使用useEffect()。这个函数主要是在DOM更改后执行副作用操作,即在渲染结束后执行

四、useMemo() 和 useCallback() 的区别

(1)useCallback和useMemo都是为了做数据缓存,useCallback返回一个函数,作为要执行的函数,useMemo返回一个值,用于使用
(2)useCallback() 主要作用于缓存一个回调函数,多用于父组件传递子组件的函数。仅当依赖值发生变更时,才会创建新的回调函数,避免了不必要渲染

这篇关于浅谈memo、PureComponent、useMemo、useEffect、useCallback的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1030855

相关文章

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

Java 关键字transient与注解@Transient的区别用途解析

《Java关键字transient与注解@Transient的区别用途解析》在Java中,transient是一个关键字,用于声明一个字段不会被序列化,这篇文章给大家介绍了Java关键字transi... 在Java中,transient 是一个关键字,用于声明一个字段不会被序列化。当一个对象被序列化时,被

解读@ConfigurationProperties和@value的区别

《解读@ConfigurationProperties和@value的区别》:本文主要介绍@ConfigurationProperties和@value的区别及说明,具有很好的参考价值,希望对大家... 目录1. 功能对比2. 使用场景对比@ConfigurationProperties@Value3. 核

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

关于Mybatis和JDBC的使用及区别

《关于Mybatis和JDBC的使用及区别》:本文主要介绍关于Mybatis和JDBC的使用及区别,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、JDBC1.1、流程1.2、优缺点2、MyBATis2.1、执行流程2.2、使用2.3、实现方式1、XML配置文件

浅谈Redis Key 命名规范文档

《浅谈RedisKey命名规范文档》本文介绍了Redis键名命名规范,包括命名格式、具体规范、数据类型扩展命名、时间敏感型键名、规范总结以及实际应用示例,感兴趣的可以了解一下... 目录1. 命名格式格式模板:示例:2. 具体规范2.1 小写命名2.2 使用冒号分隔层级2.3 标识符命名3. 数据类型扩展命

exfat和ntfs哪个好? U盘格式化选择NTFS与exFAT的详细区别对比

《exfat和ntfs哪个好?U盘格式化选择NTFS与exFAT的详细区别对比》exFAT和NTFS是两种常见的文件系统,它们各自具有独特的优势和适用场景,以下是关于exFAT和NTFS的详细对比... 无论你是刚入手了内置 SSD 还是便携式移动硬盘或 U 盘,都需要先将它格式化成电脑或设备能够识别的「文

什么是ReFS 文件系统? ntfs和refs的优缺点区别介绍

《什么是ReFS文件系统?ntfs和refs的优缺点区别介绍》最近有用户在Win11Insider的安装界面中发现,可以使用ReFS来格式化硬盘,这是不是意味着,ReFS有望在未来成为W... 数十年以来,Windows 系统一直将 NTFS 作为「内置硬盘」的默认文件系统。不过近些年来,微软还在研发一款名