首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >什么是要传递给useEffect的依赖项?

什么是要传递给useEffect的依赖项?
EN

Stack Overflow用户
提问于 2020-12-03 14:59:02
回答 2查看 44关注 0票数 0

在读取官方钩子指南时,它提到了在函数中引用的每个值也应该出现在依赖项数组中。我的问题是,什么被归类为依赖?请查看Dan的以下示例:

代码语言:javascript
复制
function Counter() {
  const [count, setCount] = useState(0);

  useEffect(() => {
    const id = setInterval(() => {
      setCount(count + 1);
    }, 1000);
    return () => clearInterval(id);
  }, [count]);

  return <h1>{count}</h1>;
}

在本例中,count被传递给依赖数组。然而,为什么setCount也没有通过呢?对我来说,这也是一种函数依赖。

更一般地,在使用useEffect时应该传递给依赖数组的依赖项被归类为依赖项。

EN

回答 2

Stack Overflow用户

发布于 2020-12-03 15:07:23

通过依赖关系,我们可以理解可能发生变化的值(状态或道具)。count是对数字的引用,每次使用新值调用setCount时,它都会发生变化。另一方面,setCount是对一个永不更改的函数的引用。

票数 0
EN

Stack Overflow用户

发布于 2020-12-03 15:13:17

我的问题是,什么被归类为依赖

通常,在functional中定义并在回调中使用的所有内容都作为第一个参数传递给useEffect。

在这种情况下,计数被传递给依赖数组。然而,为什么setCount也没有通过呢?对我来说,这也是一种函数依赖。

将setCount添加到依赖项中没有任何问题。React将确保setCount不会更改,因此从依赖项中添加/删除它不会产生任何影响。

更普遍地说,什么是在使用useEffect时应该传递给依赖数组的依赖项?

添加依赖项以避免陈旧的值,并在添加的依赖项更改时调用回调函数。

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

https://stackoverflow.com/questions/65128446

复制
相关文章

相似问题

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