首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我应该回忆一下自定义钩子中的功能吗?

我应该回忆一下自定义钩子中的功能吗?
EN

Stack Overflow用户
提问于 2019-11-21 12:35:11
回答 2查看 3.3K关注 0票数 10

我有计数器组件。我用自定义钩子封装了业务逻辑。我应该用useCallback来优化函数吗?如果在变更处理程序上有输入,情况会相同吗?

代码语言:javascript
复制
const increment = () => {
    setCount(count + 1);
};

代码语言:javascript
复制
const increment = useCallback(() => {
    setCount(count + 1);
}, [count]);

沙子

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-11-21 15:10:31

假设count和setCount来自const [count,setCount] = useState(0),那么您应该以以下方式使用回调,这样增量函数在组件的生命周期中保持不变:

代码语言:javascript
复制
const increment = useCallback(() => setCount(count => count + 1),[]);

当计数发生变化时,不需要重新创建增量,因为可以将回调传递给状态设置器函数。

票数 5
EN

Stack Overflow用户

发布于 2019-11-21 12:59:04

在功能组件范围内声明的每个函数都应该是memoized或带有useCallbackcached。如果它从组件范围引用其他变量或函数,则应该在其dependency list中列出这些变量或函数。否则,每个prop/state更改都将重新创建该函数,这是很少使用的行为。

但是在优化之前要记住测量。-即使是官方的文件也说要轻松处理这件事。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58975220

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档