React 的 useInsertionEffect 鉤子是 useEffect 的專門版本,它保證其副作用將在同一元件中的任何其他效果之前運行。這對於 DOM 操作或依賴執行前完全渲染 DOM 的第三方函式庫整合特別有用。
當你需要在元件渲染後直接操作 DOM 時,例如設定焦點、捲動到特定元素或附加事件監聽器。
如果函式庫要求 DOM 在呼叫其函數之前準備就緒,useInsertionEffect 可確保它在正確的時間執行。
對於取決於元件佈局的效果,例如測量元素尺寸或計算位置。
import { useRef, useInsertionEffect } from 'react'; function MyComponent() { const inputRef = useRef(null); useInsertionEffect(() => { if (inputRef.current) { inputRef.current.focus(); } }, []); return (); }
在此範例中,useInsertionEffect 用於確保輸入元素在渲染後立即獲得焦點。這保證了用戶可以立即開始輸入。
import { useInsertionEffect } from 'react'; function MyComponent() { useInsertionEffect(() => { const style = document.createElement('style'); style.textContent = ` .my-custom-class { color: red; font-weight: bold; } `; document.head.appendChild(style); return () => { style.remove(); }; }, []); return (This text will have red and bold styles.); }
在此範例中,useInsertionEffect 用於動態地將自訂樣式規則新增至文件頭,確保它們在元件中的任何其他效果之前套用。
React 的 useInsertionEffect 鉤子是一個強大的工具,可確保在正確的時間執行副作用,特別是在處理 DOM 操作或第三方函式庫時。透過了解其目的和用法,您可以建立更可靠、更高效能的 React 元件。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3