react经验12:等待状态更新

应用场景:

等待react组件内的state发生变更后进行后续操作。

已知问题

通常state的变化会引起dom的刷新,更新state一般使用setState,但这是个异步操作。

如果此时需要立即操作dom,得到的目标dom是刷新之前的样子。

应对方法

方法1 :使用useEffect监听state,当监听的state发生变化时会触发回调,此时的dom也刷新完毕。

举例:

js 复制代码
const [count,setCount]=useState(0)
useEffect(()=>{
//这里是state的监听回调
},[count])

方法2 :

使用timeout,调用setState后,后续操作放在timeout中处理。

举例:

js 复制代码
const [count,setCount]=useState(0)
function handleChange(val:number){
	setCount(val)
	setTimeout(()=>{
		//后续操作放在这
	})
}
相关推荐
用泥种荷花5 分钟前
【前端学习AI】大模型调用实战
前端
Lan.W28 分钟前
element UI + vue2 + html实现堆叠条形图 - 横向分段器
前端·ui·html
FAQEW30 分钟前
若依(RuoYi-Vue)单体架构实战手册:自定义业务模块全流程开发指南
前端·后端·架构·若依二开
神算大模型APi--天枢64638 分钟前
合规与高效兼得:国产全栈架构赋能行业大模型定制,从教育到工业的轻量化落地
大数据·前端·人工智能·架构·硬件架构
千寻girling43 分钟前
马上元旦节了,手写一个《前端脚手架》庆祝一下 !
前端
嚣张丶小麦兜1 小时前
认识vite
前端·javascript·vue.js
玲小珑2 小时前
请求 ID 跟踪模式:解决异步请求竞态条件
前端
开心_开心急了2 小时前
AI+PySide6实现自定义窗口标题栏目(titleBar)
前端
开心_开心急了2 小时前
Ai加Flutter实现自定义标题栏(appBar)
前端·flutter
布列瑟农的星空2 小时前
SSE与流式传输(Streamable HTTP)
前端·后端