当前位置: 首页 > news >正文

[bug修复]状态数据在useEffect初始化时更新无效

(bug修复类型的博客还是用汉语写捏)

前两天在做一个管理页面前端的时候,出现了这样的问题

function Son(props){const [a,seta]=useState(0)useEffect(()=>{seta(props.name)},[])return(<div>{a}</div>)
}

这是当时情况的一个简单复现,我在父组件中向子组件传递数据,并且想把这个数据保存在状态里面

理想很丰满,现实很骨干。在子组件的位置,返回结果仍然是0,也就是我们一开始是用useState的初始状态。就好像useEffect内部的set函数没有执行一样。

一开始的想法是useEffect本身是异步方法,因为这个钩子函数更多需要承担一些dom操作,接口获取,发送网络请求等等异步操作。所以这个东西会不会是因为异步,而产生影响。

但是这个想法有两个错误点,首先state状态类似vue中的data是响应样式的,就算是异步操作也是会执行并且发生响应样式的修改,最多等几ns的问题(当然这个想法也是有问题的,后面会说)

其次,就算我们换成了同步的useLayoutEffect函数,也是一个结果

第二个想法是,useEffect函数的执行顺序,但是这个想法和第一个想法的结果大同小异

 但是如果我不保存到状态内,而是直接使用传进来的数据,就瞬间变成了正常的响应状态!

function Son(props){return(<div>{props.name}</div>)
}

所以可以确定,问题出在state的状态没有及时更新!

但是问题不是出在hook函数本身,而是我们在内部调用的set函数。

破案:

 众所周知,useState返回的结果是一个数值,和一个异步回调函数。

如果是在js中,回调函数是在一个叫做事件队列的结构中实现的,当call stack中的上下文执行结束以后,会按照某个顺序执行存在队列中的回调函数

但是在react中,作出了一点小小的改变,回调函数其实并不是按照上下文结束以后,自然执行的。而是需要等待某个时机,这个时机其实就是重新渲染。

因此,我们像一开始那样写代码的时候,就会出现这种情况。

破解方法其实很简单,我们只要在useEffect函数的监听对列中,加入传进来的数据,这样子就可以触发重新渲染这个条件,保持了组建传递的数据可变性质

function Son(props){const [a,seta]=useState(0)useEffect(()=>{seta(props.name)},[props.name])return(<div>{a}</div>)
}

最后摘录一段gpt的回复

React 在适当的时机进行批量更新,而不是像普通 JavaScript 一样遵循自然执行的时间队列。

React 使用一种称为 "调度" 的机制来管理状态更新和组件的重新渲染。当你调用 `setState`(或 `useState` 的更新函数)时,React 会将更新请求添加到调度队列中。然后,在适当的时机,React 会处理队列中的更新请求,并进行批量更新。

React 通常会在以下情况下触发批量更新:

1. 在 React 事件处理函数中:当你在事件处理函数中调用 `setState`,React 会将更新请求添加到队列中,并在事件处理函数执行完成后进行批量更新。

2. 在生命周期方法和钩子函数中:在组件的生命周期方法(如 `componentDidMount`、`componentDidUpdate` 等)和函数组件的钩子函数(如 `useEffect`、`useLayoutEffect` 等)中调用 `setState`,React 也会将更新请求添加到队列中,并在适当的时机进行批量更新。

3. 在异步操作中:如果在异步操作的回调函数中调用 `setState`,React 会将更新请求添加到队列中,并在异步操作完成后进行批量更新。

在这些情况下,React 会等待当前的 JavaScript 执行栈为空(即当前任务结束)以及浏览器的绘制(渲染)过程即将开始时,才会执行批量更新。这样可以最大程度地优化性能,避免不必要的重复渲染。

所以,你观察到的现象是因为 React 在适当的时机才进行批量更新,而不是立即执行更新。它会等待当前渲染过程结束,然后在下一次渲染前处理队列中的更新请求。

相关文章:

[bug修复]状态数据在useEffect初始化时更新无效

&#xff08;bug修复类型的博客还是用汉语写捏&#xff09; 前两天在做一个管理页面前端的时候&#xff0c;出现了这样的问题 function Son(props){const [a,seta]useState(0)useEffect(()>{seta(props.name)},[])return(<div>{a}</div>) } 这是当时情况的一…...

使用 API Gateway Integrator 在 Quarkus 中实施适用于 AWS Lambda 的 OpenAPI

AWS API Gateway 集成使得使用符合 OpenAPI 标准的 Lambda Function 轻松实现 REST API。 关于开放API 它是一个 允许以标准方式描述 REST API 的规范。 OpenAPI规范 (OAS) 为 REST API 定义了与编程语言无关的标准接口描述。这使得人类和计算机都可以发现和理解服务的功能&am…...

【JVM】JVM中的分代回收

文章目录 分代收集算法什么是分代分代收集算法-工作机制MinorGC、 Mixed GC 、 FullGC的区别是什么 分代收集算法 什么是分代 在java8时&#xff0c;堆被分为了两份&#xff1a; 新生代和老年代【1&#xff1a;2】 其中&#xff1a; 对于新生代&#xff0c;内部又被分为了三…...

C# Linq源码分析之Take方法

概要 Take方法作为IEnumerable的扩展方法&#xff0c;具体对应两个重载方法。本文主要分析第一个接收整数参数的重载方法。 源码解析 Take方法的基本定义 public static System.Collections.Generic.IEnumerable Take (this System.Collections.Generic.IEnumerable source…...

从后往前读取列表的方法

从后往前读取列表的方法 方法1&#xff1a;使用for循环遍历列表时&#xff0c;可以使用reverse()函数将列表反转&#xff0c;然后再遍历。 # 列表 num [0, 1, 2, 3]# 反向遍历 for i in reversed(num):print(i)输出结果&#xff1a; 3 2 1 0方法2&#xff1a;先计算列表长度…...

数据库--数据类型

数据库相关链接&#xff1a; 数据库基础操作--增删改查&#xff1a;http://t.csdn.cn/189CF 数据库--三大范式、多表查询、函数sql&#xff1a;http://t.csdn.cn/udJSG 数据类型 创建表的时候&#xff0c;我们在类型这里给出了不同的选项&#xff0c;比如有int &#xff0c;…...

小型双轮差速底盘机器人实现红外跟随功能

1. 功能说明 本文示例将实现R023样机小型双轮差速底盘跟随人移动的功能。在小型双轮差速底盘前方按下图所示安装3个 近红外传感器&#xff0c;制作一个红外线发射源&#xff0c;实现当红外发射源在机器人的检测范围内任意放置或移动时&#xff0c;机器人能追踪该发射源。 2. 电…...

TCP协议网络编程 回显服务器,客户端实现

回显服务器表示客户端传来的请求是什么&#xff0c;服务器就回应什么&#xff0c;客户端不用对传来的数据进行处理&#xff0c;主要是为了熟悉TCP协议提供的API的使用 对于代码的解释全作为注释写在了代码上&#xff0c;推荐复制到编程软件中查看 UDP协议实现回显服务器可以看…...

3.4 Spring MVC注解

注解名称 注解说明 RequestMapping 用来处理请求地址映射的注解&#xff0c;可以在接口、类和方法上使用 value属性 表示请求地址&#xff0c;与path属性一致 method属性 表示接收HTTP请求方法&#xff0c;默认接收所有请求方法&#xff0c;请求包括GET、POST、PUT、DEL…...

OpenCV实例(八)车牌字符识别技术(三)汉字识别

车牌字符识别技术&#xff08;三&#xff09;汉字识别 1.代码实例2.遇到问题3.汉字识别代码实例 相较于数字和英文字符的识别&#xff0c;汽车牌照中的汉字字符识别的难度更大&#xff0c;主要原因有以下4个方面&#xff1a; (1)字符笔画因切分误差导致非笔画或笔画流失。 (2…...

运维监控学习笔记2

硬件监控&#xff1a; 1&#xff09;使用IPMI 2&#xff09;机房巡检 路由器和交换机&#xff1a; 使用SNMP&#xff08;简单网络管理协议&#xff09;进行监控。 Linux 安装snmp&#xff1a; yum install -y net-snmp net-snmp-utils 说明&#xff1a;net-snmp是安装在snm…...

【深度学习】遗传算法[选择、交叉、变异、初始化种群、迭代优化、几何规划排序选择、线性交叉、非均匀变异]

目录 一、遗传算法二、遗传算法概述2.1 选择2.2 交叉2.3 变异 三、遗传算法的基本步骤3.1 编码3.2 初始群体的生成3.3 适应度评估3.4 选择3.5 交叉3.6 变异3.7 总结 四、遗传算法工具箱4.1 initializega4.2 ga4.3 normGeomSelect4.4 arithXover4.5 nonUnifMutation 五、遗传算法…...

【小吉带你学Git】讲解GitHub操作,码云操作,GitLab操作

&#x1f38a;专栏【Git】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 &#x1f33a;欢迎并且感谢大家指出小吉的问题&#x1f970; 文章目录 &#x1f354;GitHub操作⭐安装GitHub插件⭐在idea中设置GitHub账号&…...

nginx基础

nginx 具体就是一个轻量级以及高性能的web服务软件。 nginx特点 1、稳定性高。&#xff08;但不如apache&#xff09; 2、系统资源消耗比较低。&#xff08;处理http请求的并发能力较高&#xff0c;单台处理器可以处理3w-5w的并发请求&#xff09; 注&#xff1a;一般在企…...

【Windows API】获取卷标、卷名

1、卷->卷标 使用FindFirstVolume()和FindNextVolume()函数体系&#xff0c;枚举系统所有卷&#xff08;Volume&#xff09;的例子&#xff0c;然后获取卷标、卷类型。这个方式可以枚举出没有驱动器号&#xff08;卷标&#xff09;的卷。 int TestMode1() {HANDLE hVolume…...

通过MATLAB自动产生Hamming编译码的verilog实现,包含testbench

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 1. 原理 1.1 编码规则 1.2 错误检测和纠正 2. 实现过程 2.1 编码过程 2.2 解码过程 3. 应用领域 3.1 数字通信 3.2 存储系统 3.3 ECC内存 3.4 数据传输 5.算法完整程序工程 1.算法…...

swager web服务无法显示问题

如果指定了扫描其他包 那么web文件夹里面的就扫描不到 需要加上扫描扫描web的 &#xff0c;默认什么也没有就会扫描web文件夹 但是其他模块的扫描不到 指定了扫描其他模块就需要再次指定扫描该web文件夹...

代码随想录训练营day18 二叉树

106. 从中序与后序遍历序列构造二叉树 给定两个整数数组 inorder 和 postorder &#xff0c;其中 inorder 是二叉树的中序遍历&#xff0c; postorder 是同一棵树的后序遍历&#xff0c;请你构造并返回这颗 二叉树 。 //左根右 左右根/* 第一步&#xff1a;如果数组大小为零的…...

图像的平移变换之c++实现(qt + 不调包)

1.基本原理 设dx为水平偏移量&#xff0c;dy为垂直偏移量&#xff0c;则平移变换的坐标映射关系为下公式&#xff0c;图像平移一般有两种方式。 1.不改变图像大小的平移&#xff08;一旦平移&#xff0c;相应内容被截掉&#xff09; 1&#xff09;当dx > width、dx < -wi…...

云原生K8S------Yaml文件详解

目录 一&#xff1a;K8S支持的文件格式 1&#xff0c;yaml和json的主要区别 2&#xff0c;YAML语言格式 二&#xff1a;yuml 1、查看 api 资源版本标签 2、写一个yaml文件demo 3、创建service服务对外提供访问并测试 4、详解k8s中的port 三&#xff1a;文件生成 1、kubec…...

技术迭代与未来趋势—晶体谐振器与振荡器发展与创新

晶体谐振器与振荡器自 20 世纪初发明以来&#xff0c;历经百年发展&#xff0c;已从最初的低频、低精度、大体积器件&#xff0c;迭代为高频、超高精度、微型化、低功耗的核心电子元件&#xff0c;支撑着通信、导航、工业控制、消费电子等产业的飞速发展。 ​ 一、传统石英晶振…...

【手撕C++】string入门:字符串加法实战

目录 前言 题目&#xff1a;字符串相加&#xff08;LeetCode 415&#xff09; 思路&#xff1a;模拟竖式加法 完整代码1&#xff1a; 完善代码2&#xff1a; 代码逐行 测试用例 新手必看&#xff1a;方法全解坑 坑1&#xff1a;判断条件写错&#xff0c;导致数组越界 坑…...

AI专著生成全攻略:4款AI工具大揭秘,快速完成20万字专著写作!

学术专著的写作难点&#xff0c;不仅在于能否完成初稿&#xff0c;更在于是否能够成功出版并获得认可。在目前的出版市场中&#xff0c;学术专著的受众群体相对较小&#xff0c;这使得出版社在选题时对学术价值和作者的影响力都有着严格的要求。许多书稿即使完成了初步的写作&a…...

保姆级教程:在RV1109开发板上集成RGA与DRM,搞定图像缩放硬件加速(附完整C++封装类)

RV1109/RV1126图像处理实战&#xff1a;基于RGA与DRM的高性能硬件加速方案 在嵌入式视觉应用中&#xff0c;图像缩放是最基础却最耗时的操作之一。当我们在RV1109这类Arm Cortex-A7处理器上使用OpenCV进行resize操作时&#xff0c;常常会遇到性能瓶颈。实测数据显示&#xff0c…...

别再只会用CSS Transition了!用FLIP动画思想搞定复杂位移与缩放(以扭蛋机为例)

FLIP动画原理&#xff1a;用数学思维解决前端复杂动效难题 在电商抽奖页面看到一个扭蛋缓缓下落、精准居中放大时&#xff0c;你有没有想过这种丝滑效果背后的技术实现&#xff1f;传统CSS Transition在面对元素位置突变时往往力不从心——要么出现诡异的跳跃&#xff0c;要么被…...

AzurLaneAutoScript:三分钟解放双手的碧蓝航线智能伴侣

AzurLaneAutoScript&#xff1a;三分钟解放双手的碧蓝航线智能伴侣 【免费下载链接】AzurLaneAutoScript Azur Lane bot (CN/EN/JP/TW) 碧蓝航线脚本 | 无缝委托科研&#xff0c;全自动大世界 项目地址: https://gitcode.com/gh_mirrors/az/AzurLaneAutoScript 还在为每…...

抖音批量下载终极指南:从零开始构建个人视频库的完整方案

抖音批量下载终极指南&#xff1a;从零开始构建个人视频库的完整方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback su…...

抖音下载神器:3分钟学会无水印批量下载视频、直播回放和音乐

抖音下载神器&#xff1a;3分钟学会无水印批量下载视频、直播回放和音乐 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback…...

机器审核的“防挂指南”:如何将简历重构成高精度解析的结构化数据

在留学生求职的网申环节&#xff0c;常常上演着这样一幕令人扼腕的“翻车”现场&#xff1a;候选人花费重金或大量精力&#xff0c;使用各类高级设计工具&#xff0c;制作了一份排版精美、色彩丰富的双栏简历。然而&#xff0c;在点击 Submit&#xff08;提交&#xff09;之后&…...

财务BP,财务,会计,到底有什么区别?一文帮你分清财务BP,财务,会计!

最近我发现一个挺普遍的现象&#xff1a;很多财务同行&#xff0c;哪怕已经坐到了CFO的位置&#xff0c;依然分不清财务BP、会计和财务的区别。大家总觉得它们都跟钱有关&#xff0c;可真要说谁具体负责什么、区别在哪&#xff0c;又讲不清楚。我也在财务行业干了十多年了&…...