警告:在渲染不同的元件 (BookingConfirmationModal) 時無法更新元件 (Bookings)。要在 BookingConfirmationModal 中找到錯誤的 setState() 調用,請按照描述的堆疊追蹤進行操作!
在 React 應用程式中,您經常會遇到這種可怕的錯誤。當您嘗試修改元件(Bookings)的狀態(主要是父元件),而它正在渲染另一個元件(BookingConfirmationModal)(它是子元件)並且您可能已將 setState() 函數傳遞給它作為道具。但是,這可能會導致應用程式 UI 出現意外行為和不一致。
在這篇部落格中,我將嘗試引導您了解此錯誤,調試其根源,並實施有效的解決方案以防止它再次出現在您的 React 專案中。
React 的渲染過程被設計為有效率且可預測的。當元件的狀態或屬性改變時,React 會啟動重新渲染程序。在此過程中,React 會遍歷元件樹,根據需要更新並重新渲染元件。 「渲染時無法更新狀態」錯誤的核心問題在於違反了這種可預測的渲染順序。當一個元件嘗試在自己的渲染階段修改另一個元件的狀態時,它會破壞渲染週期並可能導致:
渲染階段的狀態更新:最可能的原因是您在渲染方法內或 BookingConfirmationModal 的渲染過程中呼叫了 setState。
渲染中的副作用:您可能會直接在渲染方法中執行副作用(例如獲取資料或更新狀態),這是應該避免的。
要解決此問題,您應該確保在渲染階段不會發生狀態更新!您可以採取以下幾個步驟:
import React, { useEffect } from 'react'; const BookingConfirmationModal = ({ someProp }) => { useEffect(() => { // Perform state updates here // Example: setState(someValue); }, [someProp]); // Add dependencies if needed return ( <div> {/* Your component JSX */} </div> ); };
避免在渲染中直接更新狀態: 確保您沒有在渲染方法或渲染期間調用的任何函數中直接呼叫 setState。
檢查條件狀態更新:如果您有更新狀態的條件邏輯,請確保它不會在渲染階段執行。
檢查你的useMemo: 如果你使用了useMemo 以防萬一,請將其刪除並在子組件中使用useEffect代替,以便它能夠運行組件安裝後或將您useMemo 移至父組件。這將解決警告問題。
可能的解決方案如下 -
import { useState, useEffect } from "react"; import BookingConfirmationModal from "./BookingConfirmationModal"; function App() { const [showModal, setShowModal] = useState(false); // other code return ( <div> <h1>This is app</h1> <button onClick={() => setShowModal(true)}>Show Modal</button> {showModal ? <Testing BookingConfirmationModal={setTestingState} /> : null} </div> ); } export default App; // BookingConfirmationModal.jsx const BookingConfirmationModal= ({ setTestingState }) => { useEffect(()=> { setTestingState(false) }, [setIsModalVisible]) //or other required dependencies return ( <div> <button onClick={() => setTestingState(false)}>Close Modal</button> // other codes </div> ); }; export default BookingConfirmationModal;
編碼愉快!
想給建議:-
在 Linkedin Twitter 上找我
寄電子郵件給我:labib.ahmed.372@gmail.com
以上是渲染時錯誤的 setState() 呼叫和可能的解決方案!的詳細內容。更多資訊請關注PHP中文網其他相關文章!