react 內置hooks 詳細使用場景,使用案例

useState

場景:組件中管理局部狀態,如表單值、開關、計數器等。

const [count, setCount] = useState(0);
return <button onClick={() => setCount(count + 1)}>Click {count}</button>;

useEffect

場景:

  • 組件掛載時執行副作用(如請求數據、事件綁定)

  • 依賴變化時觸發邏輯

  • 卸載清理操作

useEffect(() => {const id = setInterval(() => console.log('tick'), 1000);return () => clearInterval(id); // 清理
}, []);

useContext

場景:狀態邏輯復雜或狀態之間有關聯的情況。常用于表單或狀態機。
多個組件傳值,層級復雜的組件之間數據傳遞,避免因為props造成難以維護的痛點

創建 context
const ThemeContext = React.createContext("light");
使用 Provider 包裹組件樹
<ThemeContext.Provider value="dark"><App />
</ThemeContext.Provider>
消費 context
const theme = useContext(ThemeContext);
return <div className={`theme-${theme}`}>當前主題:{theme}</div>;

useReducer

適用于狀態較復雜或狀態之間關聯性強的場景

基本語法
const [state, dispatch] = useReducer(reducer, initialState);
示例一:計數器
const reducer = (state, action) => {switch (action.type) {case 'increment': return state + 1;case 'decrement': return state - 1;default: return state;}
};
const [count, dispatch] = useReducer(reducer, 0);
<button onClick={() => dispatch({ type: 'increment' })}>+</button>

useReducer + useContext 配合使用(全局狀態管理)

const AppContext = createContext(null);const initialState = { user: null };
function reducer(state, action) {switch (action.type) {case 'login': return { ...state, user: action.payload };case 'logout': return { ...state, user: null };default: return state;}
}function AppProvider({ children }) {const [state, dispatch] = useReducer(reducer, initialState);return (<AppContext.Provider value={{ state, dispatch }}>{children}</AppContext.Provider>);
}function useApp() {return useContext(AppContext);
}

useCallback

場景:

  • 父組件傳遞函數給子組件

  • 避免組件重復渲染

const handleClick = useCallback(() => doSomething(id), [id]);

useMemo

場景:

  • 緩存計算結果

  • 避免重復渲染時昂貴計算

const expensiveValue = useMemo(() => computeExpensiveValue(data), [data]);

useRef

場景:

  • 訪問 DOM 元素

  • 保存可變值不觸發重渲染(如定時器ID

const inputRef = useRef<HTMLInputElement>(null);
useEffect(() => inputRef.current?.focus(), []);

useImperativeHandle

場景:暴露子組件的內部方法給父組件(配合 forwardRef 使用)

useImperativeHandle(ref, () => ({focus: () => inputRef.current?.focus()
}));

useLayoutEffect

場景:

  • 在 DOM 渲染之前同步執行副作用(如測量 DOM)
useLayoutEffect(() => {const height = ref.current.offsetHeight;// 設置樣式
}, []);

與 useEffect 類似,但在 DOM 渲染前 執行,可能阻塞繪制。

useDebugValue

useDebugValue(state ? "Online" : "Offline");

react18 相關hooks

useTransition

場景:將更新標記為“過渡”,提升響應性(如搜索輸入)

const [isPending, startTransition] = useTransition();
startTransition(() => setSearchQuery(value));

useDeferredValue

場景:延遲某個值的更新,防止因頻繁輸入導致 UI 卡頓

const deferredQuery = useDeferredValue(query);

useId

場景:在客戶端和服務端生成一致的唯一 ID(用于可訪問性)

const id = useId();
<label htmlFor={id}>Name</label>
<input id={id} />

useSyncExternalStore

場景:訂閱外部 store(如 Redux、MobX、Zustand)

const state = useSyncExternalStore(subscribe, getSnapshot);

useInsertionEffect

場景:比 useLayoutEffect 更早執行,用于樣式注入等場景(如 CSS-in-JS)

useInsertionEffect(() => {// 注入樣式
}, []);

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

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

相關文章

從0到1學Pandas(九):Pandas 高級數據結構與操作

目錄一、探秘多級索引1.1 創建多級索引1.2 多級索引操作1.3 索引轉換二、探索 Panel 與 xarray2.1 Panel 數據結構2.2 xarray 庫2.3 高維數據操作三、時間序列高級應用3.1 時區處理3.2 時間序列重采樣與頻率轉換3.3 時間序列分解與預測四、數據透視與重塑高級技巧4.1 復雜透視表…

C# 圖像轉換實戰:Bitmap 轉 BitmapSource 的 2 種方法

C# 圖像轉換實戰:Bitmap 轉 BitmapSource 的 2 種方法 引言 兩種轉換方法的完整實現 1. 基于GDI句柄的直接轉換 (ToBitmapSourceFast) 2. 基于內存流的編碼轉換 (ToBitmapSourceSafe) 方法對比與選型指南 避坑指南 GDI句柄泄漏問題 圖像顯示不完整 多線程訪問圖像引發異常 不同…

Spring Boot 整合 Spring MVC:自動配置與擴展實踐

Spring MVC 作為 Java Web 開發的核心框架&#xff0c;在傳統 SSM 項目中需要大量 XML 配置&#xff08;如 DispatcherServlet、視圖解析器等&#xff09;。而 Spring Boot 通過 "自動配置" 特性&#xff0c;簡化了 Spring MVC 的整合過程&#xff0c;同時保留了靈活…

print(“\033[31m紅\033[32m綠\033[34m藍\033[0m默認色“)

可以讓python的終端字體有著不一樣的顏色。代碼&#xff1a;print("\033[31m紅\033[32m綠\033[34m藍\033[0m默認色")效果&#xff1a;

LNMP-zblog分布式部署

一、準備3臺主機&#xff08;rocky8&#xff09;下載相應服務[rootnginx ~]# yum install -y nginx nfs-utils[rootphp ~]# yum install -y nfs-utils php-mysqlnd php php-fpm[rootmysql ~]# yum install -y mysql-server二、掛載php端[rootphp ~]# vim /etc/exports [rootphp…

常見代碼八股

1. 利用梯度下降法&#xff0c;計算二次函數yx^2x4的最小值 def target_function(x):return x ** 2 x 4def gradient(x):return 2*x 1x_init 10 x x_init steps 100 lr 0.1 for i in range(100):x x - lr*gradient(x)print(f"最小值 f(x) {target_function(x):.4f…

【深入底層】C++開發簡歷4+4技能描述6

簡歷書寫 熟悉C的封裝、繼承、多態&#xff0c;STL常用容器&#xff0c;熟悉C11的Lambda表達式、智能指針等&#xff0c;熟悉C20協程語法&#xff0c;具有良好的編碼習慣與文檔能力。 回答思路 這里是基本上就是要全會&#xff0c;考察的問題也很固定&#xff0c;stl這塊可以定…

forest遠程調用注意事項

1、如果在項目中&#xff0c;同時依賴了其中多個框架&#xff0c;那么按 Fastjson2 > Fastjson > Jackson > Gson 這樣的優先級來判斷&#xff0c;Forest 會以優先級最高的框架作為 JSON 轉換器。2、Forest 支持哪幾種 JSON 框架&#xff1f;A: 支持 Jackson、Gson、F…

網絡資源模板--基于Android Studio 實現的新聞App

目錄 一、測試環境說明 二、項目簡介 三、項目演示 四、部設計詳情&#xff08;部分) 登錄頁 首頁 五、項目源碼 一、測試環境說明 電腦環境 Windows 11 編寫語言 JAVA 開發軟件 Android Studio (2020) 開發軟件只要大于等于測試版本即可(近幾年官網直接下載也可…

通過Location API精準獲取位置信息并優化定位精度!

&#x1f44b; 你好&#xff0c;歡迎來到我的博客&#xff01;我是【菜鳥不學編程】 ?? 我是一個正在奮斗中的職場碼農&#xff0c;步入職場多年&#xff0c;正在從“小碼農”慢慢成長為有深度、有思考的技術人。在這條不斷進階的路上&#xff0c;我決定記錄下自己的學習與成…

構建可擴展的狀態系統:基于 ArkTS 的模塊化狀態管理設計與實現

摘要 在 HarmonyOS 的日常開發中&#xff0c;很多人都會遇到一個問題&#xff1a;多個頁面之間的數據狀態如何共享&#xff1f;尤其是在組件結構越來越復雜的場景下&#xff0c;如果還用傳統方式來傳值&#xff0c;不僅代碼混亂&#xff0c;維護也很吃力。 為了解決這個問題&am…

重生之我在暑假學習微服務第二天《MybatisPlus-下篇》

本系列參考黑馬程序員微服務課程&#xff0c;有興趣的可以去查看相關視頻&#xff0c;本系列內容采用漸進式方式講解微服務核心概念與實踐方法&#xff0c;每日更新確保知識點的連貫性。通過系統化學習路徑幫助開發者掌握分布式系統構建的關鍵技術。讀者可通過平臺訂閱功能獲取…

系統整理Python的條件語句和常用方法

Python 的條件語句&#xff08;if 語句&#xff09;是控制程序流程的基礎之一&#xff0c;結構清晰、語法簡潔&#xff0c;非常適合初學者掌握。一、基本語法結構if 條件:執行代碼塊1 elif 條件2:執行代碼塊2 else:執行代碼塊3示例&#xff1a;score 85if score > 90:print…

記錄個IAR程序下載后硬件復位不運行,必須斷電復位才運行的問題

【問題測試】有個F407的跑馬燈的例子&#xff0c;是MDK和IAR兩個版本&#xff0c;MDK版本的例子下載并復位后可以正常看到LED閃爍&#xff0c;而IAR的例子下進去后&#xff0c;不會閃爍。使用TOOL的上位機內核寄存器監測工具測試發現&#xff0c;硬件復位后竟然還在調試狀態&am…

觀察者模式(Observer Pattern)和 發布-訂閱模式(Publisher-Subscriber Pattern)

你對 觀察者模式&#xff08;Observer Pattern&#xff09;和 發布-訂閱模式&#xff08;Publisher-Subscriber Pattern&#xff09;的描述是非常準確的&#xff0c;并且闡明了它們的核心區別。為了幫助你更好地理解這兩者的細微差異&#xff0c;下面是一個更詳細的對比分析&am…

2025年接口技術的十字路口:當MCP遇見REST、GraphQL與gRPC

在當今這個由數據驅動、萬物互聯的時代&#xff0c;應用程序接口&#xff08;API&#xff09;已成為現代軟件架構的基石。它們是不同服務之間溝通的橋梁&#xff0c;支撐著從網頁應用到復雜的微服務生態系統的一切。長久以來&#xff0c;開發者們在REST、GraphQL和gRPC這幾種主…

【CTF-WEB-反序列化】利用__toString魔術方法讀取flag.php

題目 頁面提示輸入?code&#xff0c;那我們在網址里get一下出現了新頁面的提示&#xff0c;進入看看下面有個help.php頁面的提示&#xff0c;進入看看有一段php代碼&#xff0c;仔細分析&#xff0c;應該是要用反序列法代碼如下 class FileClass{ public $filename error.log…

在 github.com 與 sourceforge.net 上創建免費個人靜態網站、博客的區別

github.com github 屬于 git 版本管理專業網站&#xff0c;有免費和收費兩種套餐。git 的數據是存放在數據庫中的&#xff0c;要將數據庫中的數據顯示為網站的網頁&#xff0c;這需要服務器端提供專門的中間件支持才能實現。 特點&#xff1a; 官方支持&#xff1a;提供長期…

jenkins 入門指南:從安裝到啟動的完整教程

jenkins 入門指南&#xff1a;從安裝到啟動的完整教程 持續集成&#xff08;CI&#xff09;是現代開發流程中的核心環節&#xff0c;而 Jenkins 作為一款開源的 CI 工具&#xff0c;憑借簡單安裝、開箱即用、插件豐富、易于擴展等優勢&#xff0c;成為開發者的首選工具。它能自…

機器學習(重學版)基礎篇(概念與評估)

本篇參考周志華老師的西瓜書&#xff0c;但是本人學識有限僅能理解皮毛&#xff0c;如有錯誤誠請讀友評論區指正&#xff0c;萬分感謝。一、基礎概念與評估方法本節目標&#xff1a;建立理論基礎框架?1、機器學習定義機器學習是一門通過計算手段利用經驗&#xff08;以數據形式…