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只会重新渲染一次)
非必要情况下,不太建议使用
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
