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

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

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

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

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

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

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

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

全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
我就是0offer糕手:北大不乱杀
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

更多
牛客网
牛客企业服务