React 播客專欄 Vol.16|useRef 和 useMemo 是干嘛的?

👋 歡迎回到《前端達人 · React 播客書單》第 16 期(正文內容為學習筆記摘要,音頻內容是詳細的解讀,方便你理解),請點擊下方收聽


視頻版


🎙 歡迎來到《前端達人 · 播客書單》第 16 期。

今天我們來聊聊兩個非常實用但經常被誤解的 React Hook:useRef?和?useMemo

你可能在項目里“見過但沒用過”,或者“不太確定場景”,這節課我們用簡單示例和對比講清楚:

  • 它們分別在做什么?

  • 什么時候該用它們?

  • 它們和?useState?有啥不同?

? Hook 是什么來頭?

自 React 16.8 起,Hook 正式成為函數組件的第一公民,賦予它們類似類組件的能力:狀態、生命周期、副作用……

Hook 的使用有兩個前提記住:

🚫 不能寫在 if / for / 內層函數中?

? 只能寫在函數組件的“頂層作用域”

🔍 useRef 是什么?(1/3)

useRef?是用來存儲“不會引起渲染”的可變值容器

const countRef = useRef(0);console.log(countRef.current); // 訪問值
countRef.current = 100; // 修改值,不會觸發組件更新

🧠 小知識點:

  • 跟?useState?不一樣,它不會觸發渲染

  • .current?才是真正存放的值

  • 適合存儲:定時器 ID、上一次的 prop、一些中間狀態

💡 useRef 最典型用法:操作 DOM(2/3)

你可能已經遇到這個場景:

頁面加載后自動聚焦一個 input 輸入框,怎么辦?

👀 用?useRef?+?useEffect?就搞定:

function MyComponent() {const inputRef = useRef<HTMLInputElement>(null);useEffect(() => {inputRef.current?.focus(); // 聚焦 input}, []);return <input ref={inputRef} />;
}

除此之外,還可以保存:

  • 防抖 / 節流計時器

  • 頁面滾動位置

  • WebSocket 實例對象

🧱 TypeScript 下的 useRef(3/3)

在 TS 中使用?useRef?時,強烈推薦加類型標注

const inputRef = useRef<HTMLInputElement>(null);
const buttonRef = useRef<HTMLButtonElement>(null);

📌 如果初始值非 null,比如數字:

const countRef = useRef(0); // 自動推斷為 number 類型

🎁 實用小表:

DOM 元素類型

對應 TS 類型

input

HTMLInputElement

button

HTMLButtonElement

div

HTMLDivElement

🧮 useMemo 是什么?(1/2)

useMemo?用來做一件事:緩存復雜計算的結果

const memoizedValue = useMemo(() => {return expensiveCalculation(a, b);
}, [a, b]);

?? 它接受兩個參數:

1?? 一個返回值的函數 2?? 一個依賴項數組(變化才會重新執行函數)

📌 如果依賴項不變,它就會“拿緩存值”,而不是重新計算。

?? useMemo 的優點和坑點(2/2)

? 優點:

  • 減少復雜計算的頻率

  • 和?React.memo?配合,減少子組件重渲染

?? 使用注意:

不要濫用 useMemo 的幾種情況

簡單的計算,沒必要緩存

每次都變化的依賴項,等于沒緩存

想“預優化”而不是“真實遇到性能問題”

📌 小貼士:先量化,再優化。性能瓶頸是真實的,才需要 useMemo。

🧩 useRef vs useMemo 到底有啥不同?

來個表格對比最直觀👇

特性

useRef

useMemo

功能

存儲值 / 獲取 DOM 引用

緩存復雜計算結果

是否觸發渲染

? 不會觸發

? 自身不觸發,僅在依賴變動時重新計算

常見用途

input 聚焦、定時器 ID、外部狀態

大數組計算、過濾、排序等性能敏感操作

🧪 推薦實戰練習

👨?💻 練習 1:

用?useRef?實現一個自動聚焦的登錄框

👨?💻 練習 2:

用?useMemo?模擬一個耗時計算(比如 10000 項數據過濾)

🔍 bonus:

用 Chrome DevTools 看組件是否重新渲染,對比?useMemo?使用前后性能差異

如果你喜歡這種講解風格,歡迎關注《前端達人 · React播客書單》,我們一起用 40 天搞懂 React + TypeScript 的核心能力 💪

#React???#React播客???#前端播客???#前端達人???#TypeScript? ?

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

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

相關文章

漫談英偉達GPU架構進化史:從Celsius到Blackwell

在英偉達官網,我們可以清晰地看到其從1999年Celsius到2024年Blackwell的20+代架構演進。這一歷程猶如一部波瀾壯闊的科技史詩,見證了英偉達在GPU領域的卓越創新與持續引領。 NVIDIA GPU架構變遷路線: 年份 NV GPU架構變遷 2025 Blackwell 2.0 2024 Blackwell 2023-2024 Hopp…

車載通信網絡 --- CAN FD與CAN XL

我是穿拖鞋的漢子,魔都中堅持長期主義的汽車電子工程師。 老規矩,分享一段喜歡的文字,避免自己成為高知識低文化的工程師: 做到欲望極簡,了解自己的真實欲望,不受外在潮流的影響,不盲從,不跟風。把自己的精力全部用在自己。一是去掉多余,凡事找規律,基礎是誠信;二是…

DM達夢數據庫開啟SQL日志記錄功能

DM達夢數據庫開啟SQL日志記錄功能 配置SQL日志&#xff08;非必須的配置步驟&#xff0c;與主備集群配置無關&#xff0c;如果沒有需求可以跳過配置SQL日志&#xff09; sqllog.ini 配置文件用于SQL日志的配置&#xff0c;當且僅當 INI&#xff08;dm.ini&#xff09; 參數 SV…

【HW系列】—C2遠控服務器(webshell鏈接工具, metasploit、cobaltstrike)的漏洞特征流量特征

文章目錄 蟻劍、冰蝎、哥斯拉一、蟻劍&#xff08;AntSword&#xff09;流量特征二、冰蝎&#xff08;Behinder&#xff09;流量特征三、哥斯拉&#xff08;Godzilla&#xff09;流量特征 metasploit、cobaltstrike一、Metasploit流量特征二、CobaltStrike流量特征三、檢測與防…

手機平板等設備租賃行業MDM方案解析

目錄 引言&#xff1a;MDM 在租賃行業的重要性日益凸顯 用戶場景&#xff1a;租賃公司面臨的主要挑戰 1. 設備丟失、逾期未還 2. 手動配置和恢復效率低 3. 非授權使用頻繁 4. 時區設置混亂影響運維 5. 缺乏實時監管能力 EasyControl MDM&#xff1a;租賃設備的遠程管控…

前端面試核心考點全解析

前端面試常見問題及解析大綱 核心技術篇 HTML相關問題 1. HTML5新特性解析 語義化標簽&#xff08;<header>、<section>等&#xff09;的作用與示例本地存儲&#xff08;localStorage與sessionStorage&#xff09;的差異 localStorage.setItem(key, value); c…

Selenium 測試框架 - Kotlin

??Selenium Kotlin 實踐指南:以百度搜索為例的完整測試示例 隨著測試自動化的普及,Selenium 已成為 Web 自動化測試的事實標準,而 Kotlin 憑借其簡潔語法和高安全性,越來越受到開發者歡迎。本指南將通過一個完整的實戰案例——在百度中執行搜索操作,來展示如何使用 Sele…

vscode調試stm32,Cortex Debug的配置文件lanuch.json如何寫,日志

https://blog.csdn.net/jiladahe1997/article/details/122046665 https://discuss.em-ide.com/blog/67-cortex-debug 第一版 {// 使用 IntelliSense 了解相關屬性。 // 懸停以查看現有屬性的描述。// 欲了解更多信息&#xff0c;請訪問: https://go.microsoft.com/fwlink/?li…

反范式設計應用場景解析

反范式設計應用場景解析 1. 反范式設計核心概念 反范式設計是指為了特定性能優化目標,在數據庫設計中故意違反關系數據庫的范式規則(通常是第三范式或BC范式),通過引入冗余數據或合并表結構來提升查詢效率的設計方法。 關鍵結論:反范式不是對范式理論的否定,而是在特定…

算法-js-子集

題&#xff1a;給你一個整數數組 nums &#xff0c;數組中的元素 互不相同 。返回該數組所有可能的子集&#xff08;冪集&#xff09;。解集 不能 包含重復的子集。你可以按 任意順序 返回解集。 方法一&#xff1a;迭代法 核心邏輯&#xff1a;動態擴展子集&#xff0c; 小規…

python里的NumPy算法

NumPy&#xff08;Numerical Python&#xff09;是 Python 中用于科學計算的基礎庫&#xff0c;提供了高性能的多維數組對象、矩陣運算以及大量數學函數庫。其核心優勢在于通過向量化操作替代傳統循環&#xff0c;大幅提升計算效率&#xff0c;尤其適合處理大規模數據的算法實現…

HarmonyOS優化應用文件上傳下載慢問題性能優化

一、概述 在開發應用時&#xff0c;客戶端與服務器之間數據交換的效率取決于文件傳輸的性能。一個數據交換性能較低的應用會導致其在加載過程中耗費較長時間&#xff0c;在很多的場景造成頁面卡頓&#xff0c;極大的影響了用戶體驗。相反&#xff0c;一個數據交換高效的應用&a…

64、【OS】【Nuttx】任務休眠與喚醒:clock_nanosleep

背景 之前的 blog 63、【OS】【Nuttx】任務休眠與喚醒&#xff1a;sleep 分析了任務休眠中的 sleep 函數&#xff0c;下面繼續來分析下 sleep 函數中的核心功能 clock_nanosleep clock_nanosleep usleep 上篇 blog 分析了 sleep 函數&#xff0c;其核心功能封裝到了 clock_…

【生產實踐】華為存儲XSG1在RHEL 7.x/8.x上的多路徑配置操作手冊(生產環境)

一、概述 本手冊針對Red Hat Enterprise Linux 7.x/8.x系統與華為XSG1存儲設備的多路徑I/O&#xff08;MPIO&#xff09;配置&#xff0c;通過優化路徑策略實現高可用、負載均衡及故障容錯&#xff0c;適配華為存儲硬件特性&#xff0c;滿足生產環境需求。 二、參數解析與配置…

Unity開發之Webgl自動更新程序包

之前讓客戶端更新webgl程序是在程序里寫版本號然后和服務器對比&#xff0c;不同就調用 window.location.reload(true);之前做的客戶端都是給企業用&#xff0c;用戶數少看不出來啥問題。后來自己開發一個小網站&#xff0c;用戶數量還是挺多&#xff0c;然后就會遇到各種各樣的…

一個開源腳本,可自動安裝在 AMD Radeon 7900XTX 上運行選定 AI 接口所需的所有內容

?一、軟件介紹 文末提供程序和源碼下載 一個開源腳本&#xff0c;可自動安裝在 AMD Radeon 7900XTX 上運行選定 AI 接口所需的所有內容。 二、ROCm-AI-Installer ROCm-AI-安裝程序 一個開源腳本&#xff0c;可自動安裝在 AMD Radeon 7900XTX 上運行選定 AI 接口所需的所有內…

【Axure結合Echarts繪制圖表】

1.繪制一個矩形&#xff0c;用于之后存放圖表&#xff0c;將其命名為test&#xff1a; 2.新建交互 -> 載入時 -> 打開鏈接&#xff1a; 3.鏈接到URL或文件路徑&#xff1a; 4.點擊fx&#xff1a; 5.輸入&#xff1a; javascript: var script document.createEleme…

Relooking:損失權重λ 、梯度權重α、學習率η

一般多任務&#xff0c;大家都喜歡疊加很多損失&#xff0c;由此產生很多損失權重系數。此外&#xff0c;有的學者直接對梯度進行操作。咋一看&#xff0c;上面三個系數貌似重復多余&#xff0c;直接用其中一個系數代替不行嗎&#xff1f;為此&#xff0c;回顧了下神經網絡的前…

數學復習筆記 20

復習方程組&#xff0c;還有隨便復習一下高數和矩陣&#xff0c;向量。現在是復習高數的導數這一章。兩個曲線相切&#xff0c;列出方程&#xff0c;然后解出參數&#xff0c;沒有任何難度呢。算切線方程&#xff0c;就是&#xff0c;算導數&#xff0c;導數就用導數定義&#…

Sqlalchemy 連mssql坑

連接失敗: (pyodbc.OperationalError) (08001, [08001] [Microsoft][ODBC Driver 17 for SQL Server]SSL Provider: [error:0A00014D:SSL routines::legacy sigalg disallowed or unsupported] (-1) (SQLDriverConnect)) (Background on this error at: https://sqlalche.me/e/…