小编use*_*101的帖子

将数组传递给 useEffect 依赖列表

有一些数据来自每 5 秒的长轮询,我希望我的组件在每次数组的一项(或数组长度本身)发生变化时分派一个动作。在将数组作为依赖项传递给 useEffect 时,如何防止 useEffect 进入无限循环,但如果任何值发生更改,仍然设法调度某些操作?

useEffect(() => {
  console.log(outcomes)
}, [outcomes])
Run Code Online (Sandbox Code Playgroud)

其中outcomes是一组 ID,例如[123, 234, 3212]. 数组中的项目可能会被替换或删除,因此数组的总长度可能 - 但不必 - 保持不变,因此outcomes.length作为依赖传递不是这种情况。

outcomes 来自 reselect 的自定义选择器:

const getOutcomes = createSelector(
  someData,
  data => data.map(({ outcomeId }) => outcomeId)
)
Run Code Online (Sandbox Code Playgroud)

reactjs react-hooks

27
推荐指数
3
解决办法
2万
查看次数

标签 统计

react-hooks ×1

reactjs ×1