React里面useMemo和useCallBack的区别

useMemo 和 useCallback 接收的参数都是一样,第一个参数为回调,第二个参数为要依赖的数据。

**相同部分:**都是依赖数据发生变化,才会去更新缓存数据

不同部分:

useMemo缓存的是二次计算的数据,主要用于缓存计算结果的值,跟vue里面的computed大致相同的作用,这样避免组件重新渲染的时候,再重新执行整个函数,导致之前的二次计算也会重新执行一次

示例:

javascript 复制代码
import { useMemo, useState } from 'react'

export default function () {
    const [num, setNum] = useState(0)
    const [val, setVal] = useState("");

    const countNum = useMemo(function getCount() {
        console.log("getCount函数调用了")
        return num+ 100;
  },[num])
    return(
        <div>
            <h1>总数:{ countNum }</h1>
            <button onClick={() => setNum(num+ 1)}>+1</button>
            <input value={val} type="text" onChange={e=>setVal(e.target.value)} />
        </div>
    )
}

useCallBack计算结果是函数, 主要用于缓存函数,应用场景如: 需要缓存的函数,因为函数式组件每次任何一个 useState 的变化,整个组件都会被重新刷新,一些函数是没有必要被重新刷新的,此时就应该缓存起来,提高性能,和减少资源浪费。

示例看我之前的这篇文章:react组件渲染性能优化之函数组件-useCallback使用-CSDN博客

相关推荐
少云清7 分钟前
【UI自动化测试】5_web自动化测试 _元素操作和元素信息获取
前端·web自动化测试
lyyl啊辉1 小时前
2. Vue数据双向绑定
前端·vue.js
CappuccinoRose2 小时前
CSS 语法学习文档(十七)
前端·css·学习·布局·houdini·瀑布流布局·csspaintingapi
keyborad pianist2 小时前
Web开发 Day1
开发语言·前端·css·vue.js·前端框架
Never_Satisfied2 小时前
在HTML & CSS中,可能导致父元素无法根据子元素的尺寸自动调整大小的情况
前端·css·html
We་ct2 小时前
LeetCode 101. 对称二叉树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
码云数智-大飞2 小时前
微前端架构落地实战:qiankun vs Module Federation 2026 深度对比与选型指南
前端·架构
IT枫斗者3 小时前
MyBatis批量插入性能优化:从5分钟到3秒的工程化实践
前端·vue.js·mysql·mongodb·性能优化·mybatis
平安的平安3 小时前
【OpenHarmony】React Native鸿蒙实战:SegmentControl 分段控件详解
react native·react.js·harmonyos
前端 贾公子3 小时前
深入理解 Vue3 的 v-model 及自定义指令的实现原理(中)
前端·html