React18状态批处理怎么使用
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,本篇内容介绍了"React18状态批处理怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!状态自
千家信息网最后更新 2025年01月18日React18状态批处理怎么使用
本篇内容介绍了"React18状态批处理怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
状态自动批处理
18版本之前, 在合成事件之外的原生事件中(例如 setTimeout, onclick, promise) , 更新状态并不会进行批量处理(合并), 这意味着在原生事件中多次调用状态更新会造成多次应用的重新渲染, 往往我们只需要最后一次即可, react在18版本后优化了这个问题
import { useState } from 'react' function App() { const [num1, setNum1] = useState(1) const [num2, setNum2] = useState(1) const add = () => { setTimeout(() => { setNum1((pre) => pre + 1) setNum2((pre) => pre + 1) }) } console.log('渲染了') return ()} export default Appreact 18 num1 : {num1}
num2 : {num2}
17版
点击四下后,组件渲染了8次
18版
点击4下后, 组件渲染了4次
退出状态自动批处理
在某些场景下 我们可能不需要批处理状态更新, 此时我们需要用到 react-dom 提供的flushSync函数, 该函数需传入一个回调, 并且会同步刷新回调中的状态更新
import { useState } from 'react'import { flushSync } from 'react-dom' function App() { const [num1, setNum1] = useState(1) const [num2, setNum2] = useState(1) const add = () => { setTimeout(() => { flushSync(() => { setNum1((pre) => pre + 1) }) flushSync(() => { setNum2((pre) => pre + 1) }) }) } console.log('渲染了') console.log(num1, num2) return ()} export default Appreact 18 num1 : {num1}
num2 : {num2}
要点概述
1. 原生事件内状态更新改为批量处理
2. 不需要批量处理时 使用 react-dom 提供的flushSync函数, 此函数同步刷新参数回调内的状态更新
"React18状态批处理怎么使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
状态
更新
事件
函数
处理
内容
更多
版本
知识
组件
实用
学有所成
接下来
参数
困境
场景
实际
情况
意味
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全网络文明背景图
赴日软件开发
网络安全检测评估的次数
网络安全管理职位薪资
四叶草网络安全
华为网络技术部门虎扑
宁夏软件开发流程与步骤
数据库减小了数据冗余
怎么下载神奇宝贝手机版服务器
内网文件共享服务器管理软件
数据库外键会限制什么
数据库单个显示可疑
高性能服务器租用
谈网络安全的重要性作文
太上老君的金丹网络安全
中专网络安全专业怎么样
aurora数据库是哪个公司
iis在服务器中怎样打开
互联网科技元素宇宙
瑞丰钢铁软件开发
本地服务器可以局域网联机吗
Cod5局域网联机看不到服务器
维护公司计算机网络安全
宁波手机软件开发服务
arma3加速哪个服务器
网络安全设计的原则是什么
南航网络技术与应用实践
win7域服务器
网络安全的客户价值
华为服务器开机按