面试官:useMemo和useCallback有什么区别?

useMemo 和 useCallback是react中两个非常重要的hook,两者之间的区别也是非常高频的面试题,但是很多同学在面试时候回答的都不是很完整,老规矩,点赞收藏支持一下,给我一分钟,理想哥教大家该怎么满分回答这个问题

如果我是求职者,我会这么回答:

在react的更新规则中,只要组件的 props 或 state 发生了变化就会重新渲染整个组件,这也导致了可能一个小改动就要重新渲染其他不必要渲染的节点,对性能是一个很大的浪费。所以react性能优化中有一个重要的方案就是减少不必要的渲染,useMemo 和 useCallback 就是方案之一。

其中,useMemo可以缓存计算数据的值。如果组件中有一段复杂的计算逻辑,可以使用useMemo,这样就不会每次都重新渲染计算逻辑,只有在依赖的数据发生变化的时候,才会需要重新计算

useCallback是useMemo的语法糖,是「useMemo 的返回值为函数」时的特殊情况,缓存的是函数的引用。如果组件中有一个函数,使用useCallback,可以实现只有在依赖的数据发生变化的时候,函数才会重新渲染。

以上,就是useMemo 和 useCallback之间的区别了,大家可以下次面试时试试这么回答,看看效果怎么样。

最后,欢迎大家关注理想哥,每天学点前端面试小技巧。

全部评论

相关推荐

但听说转正率很低,我现在有在实习了,好纠结要不要去
熬夜脱发码农:转正率低归低,但是实习的经历你可以拿着,又不是说秋招不准备了
点赞 评论 收藏
分享
迟缓的斜杠青年巴比Q...:简历被投过的公司卖出去了,我前两天遇到过更离谱的,打电话来问我有没有意向报班学Java学习,服了,还拿我学校一个学长在他们那报班学了之后干了华为OD当招牌
点赞 评论 收藏
分享
zhch7:建议9✌️把学历加黑加粗,如果实在offer可能是觉得佬不会去
投了多少份简历才上岸
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务