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

相关推荐
亿元程序员1 分钟前
Cocos视频拼图,拼图游戏的最后一块碎片,支持原生!
前端
Rabbit_QL4 分钟前
【前端工具链小白篇】前端工具链全景:Node、npm、Vite 各管什么
前端·npm·node.js
身如柳絮随风扬4 分钟前
前端基础进阶:Node.js + ES6 + Axios + Vue 全面入门指南
前端·node.js·es6
byoass7 分钟前
文件版本管理的设计与实现:解决协同编辑丢数据的核心方案
前端·javascript·网络·数据库·安全·云计算
yqcoder11 分钟前
前端性能优化基石:深入解析 CSS 雪碧图 (CSS Sprites)
前端·css·性能优化
身如柳絮随风扬11 分钟前
Vue项目搭建与实战:从vue-cli到vue-admin-template完整指南
前端·javascript·vue.js
最后一只小白21 分钟前
封装form表单
前端·javascript·vue.js
魔士于安21 分钟前
Unity类似博物馆场景
前端·unity·游戏引擎·贴图·模型
喜欢吃鱿鱼22 分钟前
vue 数字转千分位js
前端·javascript·vue.js
吴声子夜歌23 分钟前
Vue3——组件进阶
前端·javascript·vue.js