React Hooks 的原理、常用函數及用途詳解

1. ??Hooks 是什么???

Hooks 是 React 16.8 引入的函數式組件特性,允許在不編寫 class 的情況下使用 state 和其他 React 特性(如生命周期、副作用等)。??本質是一類特殊函數??,它們掛載到 React 的調度系統中,在組件渲染時被調用,以“鉤入”React 的核心功能。

2. ??Hooks 的底層原理??
  • ??鏈表結構??:Hooks 通過單向鏈表記錄狀態。每次組件渲染時,React 會按順序遍歷鏈表,讀取或更新對應的狀態。
  • ??調用順序規則??:Hooks 必須保證每次渲染的調用順序一致(不能嵌套在條件/循環中),因為 React 依賴調用順序來關聯狀態。
  • ??閉包與作用域??:Hooks 利用閉包保存當前組件的上下文(如?useState?的 state 值)。
3. ??常用 Hooks 及用途??
Hook 名稱作用描述示例場景
useState管理組件內部狀態計數器、表單輸入
useEffect處理副作用(數據獲取、DOM 操作等)API 請求、事件監聽、定時器
useContext跨組件層級共享數據(替代部分 Redux 場景)主題切換、用戶身份傳遞
useReducer復雜狀態邏輯管理(類似 Redux 的 reducer)多狀態聯動、表單校驗
useCallback緩存函數,避免子組件不必要的重渲染性能優化(配合?React.memo
useMemo緩存計算結果,避免重復計算復雜計算、過濾列表數據
useRef獲取 DOM 引用或保存可變值(不觸發渲染)聚焦輸入框、保存定時器 ID
useLayoutEffect類似?useEffect,但同步執行(在 DOM 更新后、瀏覽器繪制前)測量 DOM 尺寸后同步更新
4. ??Hooks 的核心用途??
  • ??邏輯復用??:通過自定義 Hook(如?useFetch)封裝可復用的邏輯,避免高階組件(HOC)的嵌套問題。
  • ??簡化組件??:函數組件 + Hooks 替代 class 組件,代碼更簡潔(無需?this、生命周期方法)。
  • ??關注點分離??:將相關邏輯聚合到獨立的 Hook 中(如數據獲取與狀態管理分離)。
5. ??Hooks 的本質??

Hooks 是 React 提供的一組 API,它們:

  • ??不是魔法??:底層基于 JavaScript 的閉包和鏈表實現。
  • ??與 Fiber 架構協同??:React 的 Fiber 調度機制跟蹤 Hooks 的調用順序和狀態。
  • ??約束性設計??:通過規則(如“只在頂層調用”)保證狀態的一致性。
示例代碼:自定義 Hook
// 自定義 Hook:監聽窗口大小
function useWindowSize() {const [size, setSize] = useState({ width: window.innerWidth, height: window.innerHeight });useEffect(() => {const handleResize = () => setSize({ width: window.innerWidth, height: window.innerHeight });window.addEventListener('resize', handleResize);return () => window.removeEventListener('resize', handleResize);}, []);return size;
}// 使用
function MyComponent() {const { width } = useWindowSize();return <div>Window width: {width}px</div>;
}
注意事項
  • ??條件調用禁止??:Hooks 必須在組件頂層調用,不可動態增減。
  • ??性能優化??:合理使用?useMemo/useCallback?避免過度渲染。
  • ??閉包陷阱??:useEffect?的依賴數組需正確處理(如使用?useRef?解決過期閉包)。

Hooks 的設計使 React 函數組件具備了完整能力,同時推動了前端開發向函數式編程風格的演進。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86591.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86591.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86591.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

學習路之PHP--webman協程學習

學習路之PHP--webman協程學習 一、準備二、配置三、啟動四、使用 協程是一種比線程更輕量級的用戶級并發機制&#xff0c;能夠在進程中實現多任務調度。它通過手動控制掛起和恢復來實現協程間的切換&#xff0c;避免了進程上下文切換的開銷 一、準備 PHP > 8.1 Workerman &g…

linux libusb使用libusb_claim_interface失敗(-6,Resource busy)解決方案

linux libusb使用libusb_claim_interface失敗&#xff08;-6&#xff0c;Resource busy&#xff09;解決方案 ? 問題原因&#x1f6e0;? 解決方案&#x1f538; 方法一&#xff1a;分離內核驅動 libusb_detach_kernel_driver()&#x1f538; 方法二&#xff1a;使用 usb-devi…

使用mpu6500/6050, PID,互補濾波實現一個簡單的飛行自穩控制系統

首先&#xff0c;參考ai給出的客機飛機的比較平穩的最大仰府&#xff0c;偏轉&#xff0c;和防滾角度&#xff0c;如下&#xff1a; 客機的最大平穩仰俯&#xff08;Pitch&#xff09;、偏轉&#xff08;Yaw&#xff09;和防滾&#xff08;Roll&#xff09;角度&#xff0c;通…

深度解析AD7685ARMZRL7:16位精密ADC在低功耗系統中的設計價值

產品概述 AD7685ARMZRL7是16位逐次逼近型&#xff08;SAR&#xff09;ADC&#xff0c;采用MSOP-10緊湊封裝。其核心架構基于電荷再分配技術&#xff0c;支持2.3V至5.5V單電源供電&#xff0c;集成低噪聲采樣保持電路與內部轉換時鐘。器件采用偽差分輸入結構&#xff08;IN/-&a…

EXCEL 實現“點擊跳轉到指定 Sheet”的方法

&#x1f4cc; WPS 表格技巧&#xff1a;如何實現點擊單元格跳轉到指定 Sheet 在使用 WPS 表格&#xff08;或 Excel&#xff09;時&#xff0c;我們經常會希望通過點擊一個單元格&#xff0c;直接跳轉到工作簿中的另一個工作表&#xff08;Sheet&#xff09;。這在制作目錄頁…

Python格式化:讓數據輸出更優雅

Python格式化&#xff1a;讓數據輸出更優雅 Python的格式化功能能讓數據輸出瞬間變得優雅又規范。不管是對齊文本、控制數字精度&#xff0c;還是動態填充內容&#xff0c;它都能輕松搞定。 一、基礎格式化&#xff1a;從簡單拼接開始 1. 百分號&#xff08;%&#xff09;格式…

2025年滲透測試面試題總結-小鵬[實習]安全工程師(題目+回答)

安全領域各種資源&#xff0c;學習文檔&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各種好玩的項目及好用的工具&#xff0c;歡迎關注。 目錄 小鵬[實習]安全工程師 1. 自我介紹 2. 有沒有挖過src&#xff1f; 3. 平時web滲透怎么學的&#xff0c;有…

VSCode科技風主題設計詳細指南

1. 科技風設計的核心特點 科技風設計是一種強調未來感、現代感和高科技感的設計風格,在VSCode主題設計中,可以通過以下幾個核心特點來體現: 1.1 色彩特點 冷色調為主:藍色、紫色、青色等冷色調是科技風設計的主要色彩高對比度:深色背景配合明亮的霓虹色,形成強烈的視覺…

android知識總結

Activity啟動模式 standard (標準模式) 每次啟動該 Activity&#xff08;例如&#xff0c;通過 startActivity()&#xff09;&#xff0c;系統總會創建一個新的實例&#xff0c;并將其放入調用者&#xff08;啟動它的那個 Activity&#xff09;所在的任務棧中。 singleTop (棧…

第3章 MySQL數據類型

MySQL數據類型 1、數字數據類型1.1 整數類型1.2 定點類型1.3 浮點類型1.4位值類型1.5 超出范圍和溢出處理1.5.1 超出范圍處理1.5.2 溢出處理 2、日期和時間數據類型3、字符串數據類型3.1 char和varchar類型3.2 binary和varbinary類型3.3 blob 和 text類型3.4 enum類型3.4.1 創建…

label-studio的使用教程(導入本地路徑)

文章目錄 1. 準備環境2. 腳本啟動2.1 Windows2.2 Linux 3. 安裝label-studio機器學習后端3.1 pip安裝(推薦)3.2 GitHub倉庫安裝 4. 后端配置4.1 yolo環境4.2 引入后端模型4.3 修改腳本4.4 啟動后端 5. 標注工程5.1 創建工程5.2 配置圖片路徑5.3 配置工程類型標簽5.4 配置模型5.…

mysql為什么一個表中不能同時存在兩個字段自增

背景。設置sort自增。會引發錯誤 通常自增字段都是用于表示數據的唯一性。數據庫限制。需要自定義排序字段大小。

牛客round95D

原題鏈接&#xff1a;D-小紅的區間修改&#xff08;一&#xff09;_牛客周賽 Round 95 題目背景&#xff1a; 初始擁有一個長度10^100元素全為0的數組&#xff0c;進行q查詢&#xff0c;每次查詢如果區間內的元素都為0就將區間變為首項為 1、公差為 1 的等差數列&#xff1b;否…

visual studio 2022更改主題為深色

visual studio 2022更改主題為深色 點擊visual studio 上方的 工具-> 選項 在選項窗口中&#xff0c;選擇 環境 -> 常規 &#xff0c;將其中的顏色主題改成深色 點擊確定&#xff0c;更改完成

實踐篇:利用ragas在自己RAG上實現LLM評估②

文章目錄 使用ragas做評估在自己的數據集上評估完整代碼代碼講解1. RAG系統構建核心組件初始化文檔處理流程 2. 評估數據集構建3. RAGAS評估實現1. 評估數據集創建2. 評估器配置3. 執行評估 本系列閱讀&#xff1a; 理論篇&#xff1a;RAG評估指標&#xff0c;檢索指標與生成指…

微軟PowerBI考試 PL300-在 Power BI 中清理、轉換和加載數據

微軟PowerBI考試 PL300-在 Power BI 中清理、轉換和加載數據 Power Query 具有大量專門幫助您清理和準備數據以供分析的功能。 您將了解如何簡化復雜模型、更改數據類型、重命名對象和透視數據。 您還將了解如何分析列&#xff0c;以便知曉哪些列包含有價值的數據&#xff0c;…

PostgreSQL 安裝與配置全指南(適用于 Windows、macOS 與主流 Linux 發行版)

PostgreSQL 是一個功能強大、開源、穩定的對象關系數據庫系統&#xff0c;廣泛用于后端開發、數據處理與分布式架構中。本指南將手把手教你如何在 Windows、macOS 以及主流 Linux 發行版 上安裝 PostgreSQL&#xff0c;并附上安裝驗證命令與基礎配置方法。 一、Windows 安裝與配…

WordPress博客文章SEO的優化技巧

在數字時代&#xff0c;博客不僅用于表達觀點&#xff0c;也能提升品牌影響力并吸引潛在客戶。許多服務器提供商&#xff08;如 Hostease&#xff09;支持 WordPress 一鍵安裝功能&#xff0c;方便新手快速完成安裝&#xff0c;專注于內容創作和 SEO 優化。然而&#xff0c;寫出…

Python:操作 Excel 折疊

??親愛的技術愛好者們,熱烈歡迎來到 Kant2048 的博客!我是 Thomas Kant,很開心能在CSDN上與你們相遇~?? 本博客的精華專欄: 【自動化測試】 【測試經驗】 【人工智能】 【Python】 Python 操作 Excel 系列 讀取單元格數據按行寫入設置行高和列寬自動調整行高和列寬水平…

雨季智慧交通:從車輛盲區到客流統計的算法全覆蓋

雨季智慧交通中的視覺分析技術應用 一、背景&#xff1a;雨季交通的復雜挑戰 雨季是城市交通管理的關鍵考驗期。以濟南為例&#xff0c;強對流天氣伴隨的短時強降水、雷雨大風及冰雹&#xff0c;不僅導致道路積水、能見度驟降&#xff0c;還加劇了大型車輛&#xff08;如渣土…