理解 useState 中的雙重渲染
在 React 中,useState 鉤子通常用於管理元件狀態。但是,在某些條件下,您可能會注意到使用 useState 呈現的元件對於每次狀態更新都會呈現兩次。這種行為讓許多未啟用嚴格模式的開發人員感到困惑。為什麼會發生這種情況?
嚴格模式的作用
與未啟用嚴格模式的假設相反,您的程式碼實際上是在其約束下運行的。預設情況下,現代版本的 React 隱式地將最外層元件包裝在
嚴格模式下的雙重函數呼叫
React 的文檔明確指出嚴格模式有意「雙重呼叫」某些函數,包括傳遞給setState 和useState 的狀態更新器函數。這意味著每當您在程式碼中呼叫 setNumber 時,它都會被呼叫兩次。
雙重呼叫的後果
此雙重呼叫會導致元件被渲染兩次。此行為旨在透過使潛在的副作用更具確定性來幫助開發人員發現潛在的副作用。預設情況下,React 在使用 useState 鉤子時會延遲更新。然而,嚴格模式繞過了這個行為,導致渲染發生兩次。
結論
總之,使用 useState 的組件的雙重渲染是運行你的React 嚴格模式下的程式碼。雖然這看起來可能出乎意料,但這種行為是有意為之的,旨在透過使副作用更加明顯來增強調試能力。
以上是為什麼 useState 在嚴格模式下渲染元件兩次?的詳細內容。更多資訊請關注PHP中文網其他相關文章!