当前位置: 首页 > Web前端 > HTML

React18setState的自动批处理

时间:2023-03-28 15:00:30 HTML

鏈枃缈昏瘧鑷猂eact浣滆€匘anAbramov鍙戣〃鐨勪竴鏈熼珮璋冩枃绔犮€傛枃鏈湁鍘熸枃閾炬帴銆傛枃绔犻€氫織鏄撴噦锛屽彲璇绘€т篃涓嶉敊锛屽垎浜粰澶у銆傛杩庡React18鎰熷叴瓒g殑鏈嬪弸涓€璧峰涔犺璁恒€傛杩癛eact18閫氳繃榛樿鎵ц鏇村鎵瑰鐞嗘潵澧炲姞寮€绠卞嵆鐢ㄧ殑鎬ц兘鏀硅繘锛屼粠鑰屾秷闄や簡鍦ㄥ簲鐢ㄧ▼搴忔垨搴撲唬鐮佷腑鎵嬪姩鎵瑰鐞嗘洿鏂扮殑闇€瑕併€傝繖绡囨枃绔犲皢瑙i噴浠€涔堟槸鎵瑰鐞嗭紝瀹冭繃鍘绘槸濡備綍宸ヤ綔鐨勶紝浠ュ強鍙戠敓浜嗕粈涔堝彉鍖栥€傛敞鎰忥細杩欐槸涓€涓繁鍏ョ殑鍔熻兘锛屾垜浠笉甯屾湜澶у鏁扮敤鎴烽渶瑕佽€冭檻銆備絾瀹冨彲鑳戒笌甯冮亾鑰呭拰React搴撳紑鍙戜汉鍛樺瘑鍒囩浉鍏炽€備粈涔堟槸鎵瑰鐞嗘壒澶勭悊鏄疪eact灏嗗涓姸鎬佹洿鏂板垎缁勫埌涓€涓崟鐙殑閲嶆柊娓叉煋涓互鑾峰緱鏇村ソ鎬ц兘鐨勬搷浣溿€備緥濡傦紝濡傛灉鎮ㄥ湪鍚屼竴涓偣鍑讳簨浠朵腑鏈変袱涓姸鎬佹洿鏂帮紝React灏嗗缁堝皢瀹冧滑鎵瑰鐞嗕负涓€涓噸鏂版覆鏌撱€傚鏋滀綘杩愯涓嬮潰鐨勪唬鐮侊紝浣犱細鐪嬪埌React姣忔鐐瑰嚮鍙墽琛屼竴娆℃覆鏌擄紝鍗充娇浣犺缃簡涓ゆ鐘舵€侊細functionApp(){const[count,setCount]=useState(0);const[flag,setFlag]=useState(false);鍑芥暟handleClick(){setCount(c=>c+1);//杩樻病鏈夐噸鏂版覆鏌搒etFlag(f=>!f);//杩樹笉閲嶆柊娓叉煋//React鍙細鍦ㄦ渶鍚庨噸鏂版覆鏌撲竴娆★紙杩欐槸鎵瑰鐞嗭紒锛墋return(

Next{count}
);}鉁呮紨绀猴細鍦ㄤ簨浠跺鐞嗙▼搴忎腑鍙嶅簲17涓壒娆°€傦紙璇锋敞鎰忥紝鎺у埗鍙颁腑鐨勬瘡娆$偣鍑婚兘浼氬憟鐜颁竴娆°€?杩欏鎬ц兘寰堟湁甯姪锛屽洜涓哄畠閬垮厤浜嗕笉蹇呰鐨勯噸鏂版覆鏌撱€傚畠杩樺彲浠ラ槻姝㈡偍鐨勭粍浠跺憟鐜扳€滃崐瀹屾垚鈥濈姸鎬侊紝鍏朵腑鍙湁涓€涓姸鎬佸彉閲忚鏇存柊锛岃繖鍙兘浼氬鑷撮敊璇€傝繖鍙兘浼氳鎮ㄦ兂璧烽鍘呮湇鍔″憳锛屼粬浠湪鎮ㄩ€夋嫨绗竴閬撹彍鏃朵笉浼氳窇鍒板帹鎴匡紝鑰屾槸绛夊緟鎮ㄥ畬鎴愯鍗曘€傜劧鑰岋紝React鐨勬壒閲忔洿鏂版椂闂村苟涓嶄竴鑷淬€備緥濡傦紝濡傛灉鎮ㄩ渶瑕佽幏鍙栨暟鎹劧鍚庢洿鏂癶andleClick涓婄殑鐘舵€侊紝鑰屼笉鏄壒澶勭悊鏇存柊锛孯eact灏嗘墽琛屼袱涓崟鐙殑鏇存柊銆傝繖鏄洜涓篟eact杩囧幓鍙湪娴忚鍣ㄤ簨浠讹紙渚嬪鐐瑰嚮锛夋湡闂存壒閲忔洿鏂帮紝浣嗚繖閲屾垜浠湪浜嬩欢澶勭悊鍚庢洿鏂扮姸鎬侊紙鍦╢etch鍥炶皟涓級锛歠unctionApp(){const[count,setCount]=useState(0);const[flag,setFlag]=useState(false);functionhandleClick(){fetchSomething().then(()=>{//React17鍜屾洿鏃╃増鏈笉浼氭壒澶勭悊杩欎簺鍥犱负//瀹冧滑鍦ㄥ洖璋冧腑*鍦?浜嬩欢涔嬪悗杩愯锛岃€屼笉鏄?鍦?鏈熼棿杩愯setCount(c=>c+1);//瀵艰嚧閲嶆柊娓叉煋setFlag(f=>!f);//瀵艰嚧閲嶆柊娓叉煋});}return(
Next{count}
);}鍦≧eact18涔嬪墠锛屾垜浠彧鍦≧eact浜嬩欢澶勭悊绋嬪簭鏈熼棿鎵归噺鏇存柊銆傞粯璁ゆ儏鍐典笅锛孯eact涓嶄細鎵瑰鐞唒romises銆乻etTimeouts銆佹湰鏈轰簨浠跺鐞嗙▼搴忔垨React榛樿涓嶄細鎵瑰鐞嗙殑鍏朵粬浜嬩欢銆備粈涔堟槸鑷姩鎵瑰鐞嗭紵浠嶳eact18鐨刢reateRoot寮€濮嬶紝鎵€鏈夋洿鏂伴兘灏嗚嚜鍔ㄦ壒澶勭悊锛屾棤璁哄畠浠潵鑷摢閲屻€傝繖鎰忓懗鐫€瓒呮椂銆佹壙璇恒€佹湰鏈轰簨浠跺鐞嗙▼搴忔垨浠讳綍鍏朵粬浜嬩欢鍐呯殑鏇存柊灏嗕互涓嶳eact浜嬩欢鍐呯殑鏇存柊鐩稿悓鐨勬柟寮忚繘琛屾壒澶勭悊銆傛垜浠笇鏈涜繖浼氬噺灏戞覆鏌撳伐浣滐紝浠庤€屾彁楂樺簲鐢ㄧ▼搴忕殑鎬ц兘锛歠unctionApp(){const[count,setCount]=useState(0);const[flag,setFlag]=useState(false);functionhandleClick(){fetchSomething().then(()=>{//React18鍙婃洿楂樼増鏈‘瀹炴壒澶勭悊杩欎簺锛歴etCount(c=>c+1);setFlag(f=>!f);//React鍙細鏈€鍚庨噸鏂版覆鏌撲竴娆★紙杩欐槸鎵瑰鐞嗭紒锛墋);}return(
Next{count}
);}鉁呮紨绀猴細鍦ㄤ簨浠跺鐞嗕箣澶栬繘琛孯eact18createRoot鎵瑰鐞嗭紒锛堟敞鎰忔帶鍒跺彴涓殑姣忔鐐瑰嚮娓叉煋锛侊級馃煛婕旂ず锛歊eact18withlegagerender淇濈暀鏃ц涓猴紙娉ㄦ剰鎺у埗鍙颁腑鐨勬瘡娆$偣鍑绘覆鏌撱€傦級娉ㄦ剰锛氫綔涓洪噰鐢≧eact18鐨勪竴閮ㄥ垎锛屾偍搴旇鍗囩骇鍒癱reateRoot銆傛棫琛屼负鐨勫憟鐜板彧鏄负浜嗘洿瀹规槗鍦ㄧ敓浜т腑璇曢獙杩欎袱涓増鏈€傛棤璁哄彂鐢熷湪浣曞锛孯eact閮戒細鑷姩鎵归噺鏇存柊锛屽洜姝わ細functionhandleClick(){setCount(c=>c+1);璁剧疆鏍囧織锛坒=>锛乫锛夛紱//React鍙細鍦ㄦ渶鍚庨噸鏂版覆鏌撲竴娆★紙杩欐槸鎵瑰鐞嗭紒锛墋涓庢鐩稿悓锛?setTimeout)setTimeout(()=>{setCount(c=>c+1);setFlag(f=>!f);//React鍙細鍦ㄦ渶鍚庨噸鏂版覆鏌撲竴娆★紙杩欏氨鏄壒澶勭悊锛侊級},1000);涓庢鐩稿悓锛?fetch)fetch(/*...*/).then(()=>{setCount(c=>c+1);setFlag(f=>!f);//React鍙細閲嶆柊-鏈€鍚庢覆鏌撲竴娆★紙鍗虫壒澶勭悊锛侊級})琛屼负涓庢鐩稿悓锛?addEventListener)elm.addEventListener('click',()=>{setCount(c=>c+1);setFlag(f=>!f);//React鍙細鍦ㄦ渶鍚庨噸鏂版覆鏌撲竴娆★紙杩欏氨鏄壒澶勭悊锛侊級});娉ㄦ剰锛歊eact鍙細鍦ㄥ畨鍏ㄧǔ瀹氱殑鍦烘櫙涓嬫壒閲忔洿鏂般€備緥濡傦紝React纭繚瀵逛簬姣忎釜鐢ㄦ埛鍚姩鐨勪簨浠讹紙渚嬪鍗曞嚮鎴栨寜閿級锛孌OM鍦ㄤ笅涓€涓簨浠朵箣鍓嶅畬鍏ㄦ洿鏂般€備緥濡傦紝杩欏彲纭繚鍦ㄦ彁浜ゆ椂绂佺敤鐨勮〃鍗曚笉鈥嬧€嬩細琚彁浜や袱娆°€備笉鎯虫壒閲忔€庝箞鍔烇紵閫氬父锛屾壒澶勭悊鏄畨鍏ㄧ殑锛屼絾鏌愪簺浠g爜鍙兘渚濊禆浜庡湪鐘舵€佹洿鏀瑰悗绔嬪嵆浠嶥OM涓鍙栨煇浜涘唴瀹广€傚浜庤繖浜涚敤渚嬶紝鎮ㄥ彲浠ラ€夋嫨涓嶄娇鐢≧eactDOM.flushSync()杩涜鎵瑰鐞嗭細//娉ㄦ剰锛歳eact-dom锛屼笉鏄痳eactfunctionhandleClick(){flushSync(()=>{setCounter(c=>c+1);});//React鐜板湪宸茬粡鏇存柊浜咲OMflushSync(()=>{setFlag(f=>!f);});//React鐜板湪宸茬粡鏇存柊浜咲OM}鎴戜滑涓嶅笇鏈涜繖绉嶆儏鍐电粡甯稿彂鐢熴€傚Hooks鏈夊奖鍝嶅悧锛熷鏋滄偍浣跨敤Hooks锛屾垜浠笇鏈涜嚜鍔ㄦ壒澶勭悊鍦ㄧ粷澶у鏁版儏鍐典笅閮借兘鈥滄甯稿伐浣溾€濄€傦紙濡傛灉娌℃湁锛岃鍛婅瘔鎴戜滑锛侊級瀹冨璇剧▼鏈夊奖鍝嶅悧锛熻璁颁綇锛孯eact浜嬩欢澶勭悊绋嬪簭鏈熼棿鐨勬洿鏂板缁堟槸鎵瑰鐞嗙殑锛屽洜姝ゅ浜庤繖浜涙洿鏂帮紝娌℃湁浠讳綍鏀瑰彉銆傜被缁勪欢涓瓨鍦ㄨ竟缂樻儏鍐碉紝杩欏彲鑳芥槸涓棶棰樸€傜被缁勪欢鏈変竴涓疄鐜版€櫀锛屽彲浠ュ悓姝ヨ鍙栦簨浠跺唴閮ㄧ殑鐘舵€佹洿鏂般€傝繖鎰忓懗鐫€鎮ㄥ皢鑳藉鍦ㄨ皟鐢╯etState涔嬮棿璇诲彇this.state锛歨andleClick=()=>{setTimeout(()=>{this.setState(({count})=>({count:count+1}));//{count:1,flag:false}console.log(this.state);this.setState(({flag})=>({flag:!flag}));});};鍦≧eact18涓紝鎯呭喌涓嶅啀濡傛銆傜敱浜庡setTimeout鐨勬墍鏈夋洿鏂伴兘鏄壒澶勭悊鐨勶紝鍥犳React涓嶄細鍦ㄧ涓€娆″悓姝ヨ皟鐢╯etState鏃舵覆鏌撶粨鏋溾€斺€旀覆鏌撳彂鐢熷湪涓嬩竴娆℃祻瑙堝櫒鍒嗘淳鏃躲€傛墍浠ユ覆鏌撹繕娌℃湁鍙戠敓锛歨andleClick=()=>{setTimeout(()=>{this.setState(({count})=>({count:count+1}));//{count:0,鏍囧織:false}console.log(this.state);this.setState(({flag})=>({flag:!flag}));});};瑙佷唬鐮併€傚鏋滆繖鏄崌绾у埌React18鐨勯殰纰嶏紝鎮ㄥ彲浠ヤ娇鐢≧eactDOM.flushSync寮哄埗鏇存柊锛屼絾鎴戜滑寤鸿璋ㄦ厧浣跨敤瀹冿細handleClick=()=>{setTimeout(()=>{ReactDOM.flushSync(()=>{this.setState(({count})=>({count:count+1}));});//{count:1,flag:false}console.log(this.state);this.setState(({flag})=>({flag:!flag}));});};瑙佷唬鐮併€傝繖涓棶棰樹笉浼氬奖鍝嶅甫鏈塇ooks鐨勫姛鑳界粍浠讹紝鍥犱负璁剧疆鐘舵€佷笉浼氭洿鏂皍seState涓殑鐜版湁鍙橀噺锛歠unctionhandleClick(){setTimeout(()=>{console.log(count);//0setCount(c=>c+1);setCount(c=>c+1);setCount(c=>c+1);console.log(count);//0},1000)铏界劧褰撲綘浣跨敤Hooks鏃惰繖绉嶈涓哄彲鑳戒护浜烘儕璁讹紝浣嗗畠涓鸿嚜鍔ㄦ壒澶勭悊閾哄钩浜嗛亾璺€倁nstable_batchedUpdates鎬庝箞鏍凤紵涓€浜汻eact搴撲娇鐢ㄨ繖涓湭璁板綍鐨凙PI鏉ュ己鍒跺setState澶栭儴浜嬩欢澶勭悊绋嬪簭杩涜鎵瑰鐞嗭細import{unstable_batchedUpdates}from'react-dom';unstable_batchedUpdates(()=>{setCount(c=>c+1);setFlag(f=>!f);});杩欎釜API鍦?8涓粛鐒跺瓨鍦紝浣嗕笉鍐嶉渶瑕佸畠锛屽洜涓烘壒澶勭悊鏄嚜鍔ㄥ彂鐢熺殑銆傛垜浠笉浼氬湪18涓垹闄ゅ畠锛屼絾鍦ㄦ祦琛岀殑搴撲笉鍐嶄緷璧栦簬瀹冪殑瀛樺湪鍚庯紝瀹冨彲鑳戒細鍦ㄦ湭鏉ョ殑涓昏鐗堟湰涓鍒犻櫎銆傚師鏂囧湴鍧€锛歨ttps://github.com/reactwg/re...