React 中的 useMemo 和 useCallback
创始人
2024-11-04 00:40:35
0

1. useMemo语法

const memoizedValue = useMemo(() => computeExpensiveValue(a, b), deps);

1. 传入一个函数进去,会返回一个 memoized 值,需要注意的是,函数内必须有返回值;

2. 第二个参数会依赖值,当依赖值更新时,会从新计算;

2. useMemo优化示例

我们定义了一个total1函数,内部对一个数组进行求和,通过 reduce 计算总和,经过测试发现点击按钮后,只会执行 total1 ,不会执行 total2,假设total2计算量巨大,就会造成内存的浪费,通过 useMemo 可以帮我们缓存计算值。

import {useMemo, useState } from "react"  function App() {     const [count,setCount] = useState(0);     //  正常的计算方法     const total1 = ()=>{         // 页面渲染时会重新输出         console.log('total1......');         const list = [1,3,5,7,9];         // 数组求和         return list.reduce((prev,current)=>prev+current,0)     };      // 加了缓存的计算     const total2 = useMemo(()=>{         // 页面重新渲不会再次输出         console.log('total2......');         const list = [1,3,5,7,9];         // 数组求和         return list.reduce((prev,current)=>prev+current,0)      },[]);      // 点击按钮测试输出     const hindleClick = ()=>{         setCount(count+1);     }; 	return ( 		

Count:{count}

Total1:{total1()}

Total2:{total2}

) } export default App

3. useCallback语法

useCallback(callback, deps)

1. useCallback 接收 2 个参数,第一个为缓存的函数,第二个为依赖值;

2. 主要用于缓存函数,第二次会返回同样的结果;

4. useCallback优化示例

定义一个子组件在父组件中调用,当父组件更新重新渲染时,子组件也会重新渲染。然后我们对子组件加了memo对传入的参数进行检测,同时对传入子组件的方法使用useCallback进行缓存,这样当父组件在更新时,缓存的方法没有发生变化,子组件通过memo发现传入的方法没有发生改变,也就不会重新渲染,以此提高了性能。

import {memo,useCallback,useState } from "react" function App() {     const [count,setCount] = useState(0);     // 父组件点击更新     const hindleClick = ()=>{         setCount(count+1);     };     // 缓存点击方法     const handleChildClick = useCallback(()=>{         console.log("子节点点击了")     },[]);     return (         

Count:{count}

) } // 检测传入的方法是否发生变化 const Child = memo(({onClick}:any)=>{ console.log('child......') return
我是子节点
}) export default App

5. useMemo和useCallback的区别

他们都用于缓存,useCallback 主要用于缓存函数,返回一个缓存后的函数,而 useMemo 主要用于缓存值,返回一个缓存后的值。

相关内容

热门资讯

透视了解!如何提高wepoke... 《德扑之星插件下载安装软件透明挂》是一款多人竞技的德扑之星插件下载安装辅助透视游戏,你将微扑克对手来...
wpk透明挂!德州之星辅助(透... wpk透明挂!德州之星辅助(透视)一贯是有挂(详细辅助实测分享)1、不需要AI权限,帮助你快速的进行...
透视神器!德州小辅助app最新... 大家肯定在之前德州小辅助app最新版本更新内容或者德州小辅助app最新版本更新内容中玩过透视神器!德...
wepoke辅助插件!wepo... wepoke辅助插件!wepower有外挂(透视)固有是真的有挂(详细辅助重磅来袭)1、wepoke...
透视代打!governor o... 《德扑之星怎么透视作弊软件透明挂》是一款多人竞技的德扑之星怎么透视作弊辅助透视游戏,你将微扑克对手来...
微扑克wpk透视辅助!aapo... 微扑克wpk透视辅助!aapoker挂(透视)真是真的是有挂(详细辅助推荐十款);是一款可以让一直输...
透视app!Fishpoker... 透视app!Fishpoker透视辅助器教程详解,AApoker的破解方法(详细辅助德州教程);亲,...
wepoke有挂!智星德州菠萝... 您好,智星德州菠萝这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款...
透视肯定!wepoker作弊软... WePoke高级策略深度解析‌;透视肯定!wepoker作弊软件是不是真的,wepoker如何提高入...
wepoke插件!aapoke... wepoke插件!aapoker有挂(透视)从来真的有挂(详细辅助详细说明),您好,aapoker有...