首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >只触发一定条件的useEffect

只触发一定条件的useEffect
EN

Stack Overflow用户
提问于 2020-10-09 10:43:12
回答 2查看 1.4K关注 0票数 0

我对useEffect有基本的理解。如果没有第二个参数(依赖数组),它将在每个呈现上运行。对于空数组,它在第一次呈现时运行。对于数组中的参数,每当某些参数发生更改时,它都会运行。

假设我的useEffect有两个依赖项(来自GraphQL查询):result.dataresult.loading。我希望useEffect在result.data更改时运行,而result.loading是假的。例如,目的是更新Redux存储:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
useEffect(() => {
  if (result.loading) return;
  dispatch(updatePhotos([...photos, ...result.data.photos]));
}, [result.data, result.loading]);

但是有一个问题:我必须包括photos来列出依赖项。但是,photos变量将在其他地方更新,并再次触发此useEffect。

,只有当这两个变量发生变化时,我才能运行useEffect?

当然,我可以使用useState存储变量resultFetched,将其设置为useEffect中的true,然后只有当变量为false时才进行分派。但是在某种程度上,我必须将其更改为true,useEffect再次运行,因为我无法手动更改result.dataresult.loading

当有很多变量需要处理时,我不知道如何在这些情况下正确地使用useEffect。

目前,我正在构建无限滚动照片列表,其中列表是通过GraphQL部分加载的。但是当用户打开一些照片并最终返回到照片列表时,它将从Redux还原到与打开照片之前相同的状态和滚动位置。

我花了无数个小时来努力让它发挥作用,但这种使用效果的东西破坏了我的每一次尝试。)它们总是在我希望它们触发之前被触发,因为有太多的变化变量。

此外,有时我希望在useEffect (添加到依赖数组中的函数)中运行一个函数,并使用useCallback对该函数进行回溯。但是,我还必须将函数使用的所有变量添加到该useCallback的依赖数组中,以便在这些变量发生变化时重新生成函数。这意味着useEffect突然再次运行,因为依赖数组中的函数会发生变化。

如果没有函数/变量触发** useEffect**,,那么是否真的无法使用中的函数/变量?

EN

回答 2

Stack Overflow用户

发布于 2020-10-09 10:49:47

这完全取决于updatePhotos的工作方式。如果这会创建一个操作,那么问题是您在错误的位置创建了新的状态。这里不应该使用照片的先前值,因为正如您所指出的,这会导致依赖关系。

相反,您的还原器将有您可以使用的照片的旧值,您只需将新的请求数据传递给您的还原程序。

在这里详细描述:https://overreacted.io/a-complete-guide-to-useeffect/#decoupling-updates-from-actions

票数 1
EN

Stack Overflow用户

发布于 2020-10-11 13:28:56

您可以在同一个组件中拥有两个独立的useEffect函数,它们将相互独立地工作。使用一个用于照片,另一个用于加载数据。我希望这个例子能帮助你了解这件事。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import React, { useState, useEffect } from "react";
import ReactDOM from "react-dom";

function App() {
  const [count, setCount] = useState(0);
  const [count2, setCount2] = useState(0);
  const [step, setStep] = useState(1);

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

  useEffect(() => {
    const id = setInterval(() => {
      setCount2((c) => c + step);
    }, 1500);
    return () => clearInterval(id);
  }, [step]);

  return (
    <div>
      <h1>{count}</h1>
      <h1>{count2}</h1>
      <input value={step} onChange={(e) => setStep(Number(e.target.value))} />
    </div>
  );
}
ReactDOM.render(<App />, document.getElementById("container"));

请参阅沙箱https://codesandbox.io/s/react-playground-forked-6h0oz中的示例

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

https://stackoverflow.com/questions/64285661

复制
相关文章
Eclipse设置断点触发的条件
特别是我们在做循环操作的时候,一堆的循环列表,但是只有某一个值出问题,一次次的循环调试起来很费劲,这个时候,我们可以给断点设置一个触发的条件,当达到这个条件的时候,才会触发此断点,设置方法如下:
飞奔去旅行
2019/06/13
1.2K0
Eclipse设置断点触发的条件
Postgresql中VDF触发LRU淘汰的条件
也就是说当: (vfd打开的数量nfile) + (其他路径直接调用fd.c接口打开文件数量numAllocatedDescs) 超过max_safe_fds时触发LRU淘汰。
mingjie
2022/05/12
4840
图解JVM实验-触发FullGC的几个条件
其中,参数-XX:PretenureSizeThreshold,参数要设置大对象阈值为3MB,也就是超过3MB,就直接进入老年代。
简熵
2023/03/06
4230
图解JVM实验-触发FullGC的几个条件
路由剔除的触发条件和核心代码
上面描述的触发点最终删除路由的逻辑是一样的,统一在RouteInfoManager#onChannelDestroy
用户8671053
2021/09/24
4250
BFC概念和作用,触发条件
1、概念,全称是block format context,块级格式化上下文 2、触发条件 根元素 float属性不为none  position为absolute或fixed  display为inline-block, table-cell, table-caption, flex, inline-flex overflow不为visible 3、应用场景 自适应两栏布局 <style> body { width: 300px; position: relative
windseek
2018/06/15
9320
“愚蠢”的useEffect
我有一个需求,需要监听一个window.xxx的变动,并在它变动的时候更新view。
爱吃大橘
2022/12/27
3090
PostgreSQL autovacuum 优化与调试 (1 触发 autovacuum 的条件)
PostgreSQL 的数据库系统中是需要进行autovacuum 进行表级别的数据清理的。在开始autovacuum 进行调优之前实际上是需要理解为什么需要autovacuum.
AustinDatabases
2021/10/14
1.7K0
PostgreSQL autovacuum 优化与调试 (1 触发 autovacuum 的条件)
ThinkPHP6之模型事件的触发条件
最近刚好用上模型事件,但手册上对事件的触发条件却没有详细的进行说明。那么,就只能自己进行测试了。
jwj
2022/05/18
8460
JVM 源码解读之 CMS GC 触发条件
经常有同学会问,为啥我的应用 Old Gen 的使用占比没达到 CMSInitiatingOccupancyFraction 参数配置的阈值,就触发了 CMS GC,表示很莫名奇妙,不知道问题出在哪?
涤生
2019/06/14
2.5K0
React源码中的useEffect
这里不再讲useLayoutEffect,它和useEffect的代码是一样的,区别主要是:
goClient1992
2022/12/02
9880
早读《A Complete Guide to useEffect》
https://overreacted.io/a-complete-guide-to-useeffect/
icepy
2019/12/18
7710
jvm触发full gc条件(Linux内存管理机制)
GC,即就是Java垃圾回收机制。目前主流的JVM(HotSpot)采用的是分代收集算法。作为Java开发者,一般不需要专门编写内存回收和垃圾清理代码,对内存泄露和溢出的问题。与C++不同的是,Java采用的是类似于树形结构的可达性分析法来判断对象是否还存在引用。即:从gcroot开始,把所有可以搜索得到的对象标记为存活对象。缺点就是:1. 有可能不知不觉浪费了很多内存。2. JVM花费过多时间来进行内存回收。3. 内存泄露
全栈程序员站长
2022/07/28
2.7K0
jvm触发full gc条件(Linux内存管理机制)
spring注解@Conditional 按照一定的条件进行判断,满足条件给容器中注册bean
@Conditional({}) 按照一定的条件进行判断,满足条件给容器中注册bean * 在类上使用表示,满足条件会执行这个类,如果不满足则类中所有方法都不会加载 * 在方法上使用表示,满足条件会执行这个方法
全栈程序员站长
2022/11/17
2850
useLayoutEffect和useEffect的区别
大家面试的过程中有没有遇到过这样的问题呢,useLayoutEffect和useEffect的区别是什么,大家可能会回答useEffect是异步的,useLayoutEffect是同步的,这样回答面试官真的会满意慢,我们需要说清楚他们在源码中的调用时机。
长腿程序员165858
2022/12/19
4020
关于useEffect的一切
对于浏览器环境来说,只有渲染器会执行类似appendChild、insertBefore这样的DOM操作。
公众号@魔术师卡颂
2020/09/01
1.1K0
[答疑]迁移的警戒条件一定要完备不重叠吗
老师,这里说离开转换的条件要完备不重叠,那如果位置不在充电站就不做任何事,是不是就不用画两个条件了
用户6288414
2022/05/27
3250
[答疑]迁移的警戒条件一定要完备不重叠吗
useEffect与useLayoutEffect
useEffect与useLayoutEffect可以统称为Effect Hook,Effect Hook可以在函数组件中执行副作用操作,副作用是指函数或者表达式的行为依赖于外部环境,或者在这里可以理解为修改了某状态会对其他的状态造成影响,这个影响就是副作用,数据获取,设置订阅以及手动更改React组件中的DOM都属于副作用。
WindRunnerMax
2022/05/06
1.2K0
后台C++开发你一定要知道的条件变量
今天因为工作需要,需要帮同事用C语言(不是C++)写一个生产者消费者的任务队列工具库,考虑到不能使用任何第三库和C++的任何特性,所以我将任务队列做成一个链表,生产者在队列尾部加入任务,消费者在队列头部取出任务。很快就写好了,代码如下: /** * 线程池工具, ctrip_thread_pool.h * zhangyl 2018.03.23 */ #ifndef __CTRIP_THREAD_POOL_H__ #define __CTRIP_THREAD_POOL_H__ #include
范蠡
2018/04/04
7560
一文搞懂Y-GC和Full GC的触发条件
说明本次Y-GC后,可能升入老年代的对象大小超过老年代当前可用内存空间,此时必须先触发一次Old GC给老年代腾出空间,再执行Young GC。
JavaEdge
2022/01/26
4K0
点击加载更多

相似问题

防止useEffect在一定条件下触发

12

UseEffect只触发某些部分吗?

18

让useEffect监视一个条件,并且只触发一次

12

有条件地反应useEffect触发器

12

在循环中响应useEffect调用-只触发最终效果

26
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文