React如何立即更新DOM
作者:田本初
这篇文章主要介绍了React如何立即更新DOM问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
React立即更新DOM
正常情况下
react会等待set完毕后再进行页面渲染,所以在set时无法拿到更新后的dom
import { useRef, useState } from "react" export default () => { const div = useRef(null) const [count, setCount] = useState(0) const btnClick = () => { setCount(count + 1) console.log(div.current.innerHTML) } return ( <> <div ref={div}>count:{count}</div> <button onClick={btnClick}>+1</button> </> ) }
但flushSync可以强制React同步刷新提供的回调中的任何更新
有点像Vue中的$nextTick
import { useRef, useState } from "react" import { flushSync } from "react-dom" export default () => { const div = useRef(null) const [count, setCount] = useState(0) const btnClick = () => { flushSync(() => { setCount(count + 1) }) console.log(div.current.innerHTML) } return ( <> <div ref={div}>count:{count}</div> <button onClick={btnClick}>+1</button> </> ) }
但是flashSync会丧失自动批处理(多次set只会重新渲染一次)
非必要情况下,不太建议使用
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。