当前位置: 首页 > 知识库问答 >
问题:

React useState钩子调用时是否保证同时调用函数参数?

贝阳泽
2023-03-14

我有一些类似的代码:

const [thing, setThing] = useState('');
const [value, setValue] = useState({
  thing: '',
  somethingElse: '',
});

//...

setThing(aThing);
setValue((prev) => ({ ...prev, thing: aThing }));

在后面的代码中,我可以保证thing==value。东西?或者这两个useState设置程序可能在不同的时间调用?

共有1个答案

黎承颜
2023-03-14

setState是异步函数,如果不批处理更新,则第一个setState可能在第二个语句之前完成。

如果从基于React的事件(如按钮单击或输入更改)中触发,React当前将批处理状态更新。如果在React事件处理程序(如setTimeout())外部触发更新,则不会对其进行批处理。

setState()并不总是立即更新组件。它可以批处理更新或将更新推迟到以后。这使得阅读成为可能。调用setState()后立即声明可能存在的陷阱。相反,使用componentDidUpdate或setState回调(setState(updater,callback)),这两种回调都保证在应用更新后触发。如果需要基于上一个状态设置状态,请阅读下面的updater参数。

这种形式的setState()也是异步的,同一周期内的多个调用可能会被批处理在一起。例如,如果您试图在同一周期中多次增加物品数量,将导致以下等效结果:

Object.assign(
  previousState,
  {quantity: state.quantity + 1},
  {quantity: state.quantity + 1},
  ...
)

后续调用将覆盖同一周期中先前调用的值,因此数量只会增加一次。如果下一个状态取决于当前状态,我们建议使用updater函数形式,而不是:

this.setState((state) => {
  return {quantity: state.quantity + 1};
});

你可以在这里阅读更多关于反应官方文档的状态。

 类似资料:
  • 问题内容: 如果返回错误,是否仍在调用? 问题答案: 不,延迟功能不会运行。 这是log.Fatal的描述: 致命等同于Print(),然后调用os.Exit(1)。 呼叫,其描述在这里: 退出使当前程序以给定的状态码退出。按照惯例,代码零表示成功,代码零表示错误。程序立即终止;延迟功能未运行。 示范 如果您确实需要在程序完成之前正确关闭资源或执行某些任务,请不要使用。

  • 问题内容: 假设我希望能够在程序中任何地方每次引发异常时都能够记录到文件。我不想修改任何现有代码。 当然,可以将其概括为每次引发异常时都可以插入钩子。 以下代码是否被认为可以安全地执行此操作? 问题答案: 如果要记录 未捕获的 异常,只需使用sys.excepthook即可。 我不确定是否会记录 所有 引发的异常的价值,因为很多库会在内部为可能不关心的事情引发/捕获异常。

  • 我得到以下错误,不确定我在箭头函数内实例化 react 钩子时做错了什么: 错误:挂接调用无效。钩子只能在函数组件的主体内部调用。这可能是由于以下原因之一: 您可能有不匹配的React和渲染器版本(如React DOM)。 您可能违反了钩子的规则。 同一应用程序中可能有多个React副本。请参阅https://reactjs.org/link/invalid-hook-call有关如何调试和修复此

  • 在调度器钩子中打印线程切换信息 在调度器钩子中打印线程切换信息 源码/* * Copyright (c) 2006-2018, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2018-08-24 yangjie the first v

  • 假设我们有一个函数和另一个函数 我们希望编写一个Unit测试,检查是否调用了的次数和正确的参数。 那里有 但这只是指最后一次通话。所以假设调用,然后,调用的断言是。 此外,还有 这将生成一个包含正确参数的对象列表。将这个列表与我们在单元测试中创建的对象进行比较,感觉是一件非常讨厌的事情<代码>调用似乎是模拟库的一个内部类。 有更好的方法吗?我使用这个设置来测试函数的并行执行。

  • 对于新项目中的一个微服务,我目前正在考虑是否使用DynamoDB或Aurora MySQL作为底层数据存储。微服务为用户界面提供了一个REST API,还有其他几个微服务。这些其他微服务应该监听由UI连接的服务生成的事件流(事件源),以保持其他读取模型的同步。 我正在试图找出一种方法来保证发布到变更事件流的事件与对底层数据存储中数据的更改完全匹配。通常,需要考虑的是,如果REST API处理程序(

  • 我在WordPress插件中有一个简单的jQuery脚本,它使用了如下jQuery包装器: 我从WordPress仪表板中调用这个脚本,并在jQuery框架加载后加载它。 当我检查Firebug中的页面时,我总是收到错误消息: TypeError:$不是函数 $(document).Ready(function(){ 我是否应该将脚本包装在这个函数中: 这个错误我已经犯了好几次了,不知道该怎么处理

  • 问题内容: 考虑类型: 现在假设我要遍历一个类实例的集合并在每个实例上调用一些函数: 该语法非常紧凑,但感觉有点尴尬。另外,它不能在任何地方使用。例如,在语句条件中: 理想情况下,写类似 但是从Swift 2.1开始,这不是正确的语法。这种引用该函数的方式将类似于以下内容: 有没有更好的方法来引用实例函数?您如何喜欢写这样的表达式? 问题答案: 这里有两个不同的问题。的 拖尾闭合语法 可以在调用函