React18之狀態(tài)批處理的使用
react在3月29號正式發(fā)布了18版本, 此次更新包括: 狀態(tài)自動批處理, 客戶端渲染api的更新, 新的hook等很多變化, 本章先說一下狀態(tài)批處理的變化.
狀態(tài)自動批處理
18版本之前, 在合成事件之外的原生事件中(例如 setTimeout, onclick, promise) , 更新狀態(tài)并不會進行批量處理(合并), 這意味著在原生事件中多次調用狀態(tài)更新會造成多次應用的重新渲染, 往往我們只需要最后一次即可, react在18版本后優(yōu)化了這個問題
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 (
<div className="App">
<header className="App-header">react 18</header>
<p>num1 : {num1}</p>
<p>num2 : {num2}</p>
<button onClick={add}>+1</button>
</div>
)
}
export default App17版
點擊四下后,組件渲染了8次

18版
點擊4下后, 組件渲染了4次

退出狀態(tài)自動批處理
在某些場景下 我們可能不需要批處理狀態(tài)更新, 此時我們需要用到 react-dom 提供的flushSync函數, 該函數需傳入一個回調, 并且會同步刷新回調中的狀態(tài)更新
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 (
<div className="App">
<header className="App-header">react 18</header>
<p>num1 : {num1}</p>
<p>num2 : {num2}</p>
<button onClick={add}>+1</button>
</div>
)
}
export default App
要點概述
1. 原生事件內狀態(tài)更新改為批量處理
2. 不需要批量處理時 使用 react-dom 提供的flushSync函數, 此函數同步刷新參數回調內的狀態(tài)更新
到此這篇關于React18之狀態(tài)批處理的使用的文章就介紹到這了,更多相關React18 狀態(tài)批處理內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
React Native開發(fā)封裝Toast與加載Loading組件示例
這篇文章主要介紹了React Native開發(fā)封裝Toast與加載Loading組件,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09

