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博客

相关推荐
码农水水8 分钟前
阿里Java面试被问:Online DDL的INSTANT、INPLACE、COPY算法差异
java·服务器·前端·数据库·mysql·算法·面试
Coder_Boy_9 分钟前
基于SpringAI的在线考试系统-知识点管理与试题管理模块联合回归测试文档
前端·人工智能·spring boot·架构·领域驱动
吃吃喝喝小朋友13 分钟前
JavaScript事件
开发语言·前端·javascript
EEEzhenliang18 分钟前
CSS的注释
前端·css
猪猪侠|ZZXia23 分钟前
# Shell+web+hook的系统构建发布运维系统之API及前端: zzxia-lollipop-remote-gan
运维·前端
弓.长.26 分钟前
小白基础入门 React Native 鸿蒙跨平台开发:PanResponder画板涂鸦(最基础,原生但是不完善)
react native·react.js·harmonyos
Coder_Boy_26 分钟前
基于SpringAI的在线考试系统-教学管理与用户管理模块联合回归测试文档
java·前端·数据库·人工智能·spring boot
希赛网29 分钟前
网工面试:常问技术问题汇总(3)
服务器·前端·网络·网络工程师·ospf·网工面试·技术面
WYiQIU30 分钟前
普及一下字节前端岗需要达到的强度......
前端·javascript·vue.js·面试·职场和发展
切糕师学AI37 分钟前
Win11 如何彻底阻止 Edge 后台运行
前端·edge