react常用hook的實(shí)現(xiàn)示例
引言??
自 React 16.8 起,Hook 的引入徹底改變了函數(shù)組件的開發(fā)方式。Hook 讓函數(shù)組件擁有了管理狀態(tài)、處理副作用、訪問上下文等能力,大大提高了代碼的可復(fù)用性和可讀性。
一、useState—— 管理組件狀態(tài)的基礎(chǔ)
useState 是最常用的 Hook,用于在函數(shù)組件中聲明狀態(tài)變量。
用法示例:
import { useState } from 'react';
function Counter() {
const [count, setCount] = useState(0); // 初始值為0
return (
<button onClick={() => setCount(count + 1)}>
點(diǎn)擊次數(shù):{count}
</button>
);
}
特點(diǎn):
- 每次調(diào)用
setCount都會(huì)觸發(fā)組件重新渲染。 useState可以接收一個(gè)函數(shù)作為初始值(惰性初始化)。
二、useEffect—— 副作用處理器
useEffect 用于處理副作用,例如:數(shù)據(jù)獲取、事件監(jiān)聽、DOM 操作等。
用法示例:
import { useEffect } from 'react';
function Timer() {
useEffect(() => {
const id = setInterval(() => {
console.log('tick');
}, 1000);
return () => clearInterval(id); // 清理定時(shí)器
}, []); // 僅在組件掛載時(shí)執(zhí)行一次
}
特點(diǎn):
- 第一個(gè)參數(shù)是副作用函數(shù)。
- 第二個(gè)參數(shù)是依賴數(shù)組,控制副作用的執(zhí)行時(shí)機(jī)。
- 返回函數(shù)用于清理資源。
注意
在 React 18 及更高版本中,useEffect 在開發(fā)模式下會(huì)故意執(zhí)行兩次。
- 主要原因
嚴(yán)格模式(Strict Mode)的影響:React 18 在開發(fā)模式下默認(rèn)啟用嚴(yán)格模式,嚴(yán)格模式下會(huì)故意掛載、卸載、再重新掛載組件,目的是幫助開發(fā)者發(fā)現(xiàn)副作用中的錯(cuò)誤,模擬用戶行為(如快速切換頁面),確保組件的副作用能夠正確處理清理和重新設(shè)置。
- 具體表現(xiàn)
useEffect(() => {
console.log("Effect ran"); // 在開發(fā)模式下會(huì)打印兩次
return () => {
console.log("Cleanup"); // 也會(huì)執(zhí)行兩次
};
}, []);
三、useRef—— 引用 DOM 或保存可變值
useRef 用于獲取 DOM 元素的引用,或在組件間保存一個(gè)不會(huì)觸發(fā)重新渲染的變量。
用法示例:
import { useRef } from 'react';
function InputFocus() {
const inputRef = useRef(null);
const handleClick = () => {
inputRef.current.focus(); // 直接操作 DOM
};
return (
<>
<input ref={inputRef} />
<button onClick={handleClick}>聚焦輸入框</button>
</>
);
}
特點(diǎn):
ref.current可以持久保存任意值。- 常用于處理定時(shí)器、緩存值等不需觸發(fā)更新的場(chǎng)景。
四、useContext—— 跨組件共享狀態(tài)
配合 React 的 Context API,useContext 可讓你在任意子組件中訪問全局?jǐn)?shù)據(jù)。
用法示例:
import { createContext, useContext } from 'react';
const ThemeContext = createContext('light');
function ThemedButton() {
const theme = useContext(ThemeContext); // 獲取上下文值
return <button className={theme}>主題按鈕</button>;
}
特點(diǎn):
- 避免多層 props 傳遞。
useContext會(huì)訂閱 context 變化,自動(dòng)更新。
五、useMemo—— 緩存計(jì)算結(jié)果
useMemo 用于緩存耗時(shí)計(jì)算,避免不必要的重復(fù)運(yùn)算。
用法示例:
import { useMemo } from 'react';
function ExpensiveComponent({ input }) {
const result = useMemo(() => {
return expensiveCalculation(input);
}, [input]);
return <div>{result}</div>;
}
特點(diǎn):
- 只有依賴項(xiàng)發(fā)生變化時(shí)才會(huì)重新計(jì)算。
- 用于優(yōu)化性能,但請(qǐng)勿濫用。
六、useCallback—— 緩存函數(shù)引用
useCallback 返回一個(gè)記憶化的函數(shù)引用,用于避免子組件重復(fù)渲染。
用法示例:
import { useCallback } from 'react';
function Parent() {
const handleClick = useCallback(() => {
console.log('Clicked');
}, []);
return <Child onClick={handleClick} />;
}
特點(diǎn):
- 與
useMemo類似,但用于緩存函數(shù)。 - 在需要傳遞穩(wěn)定函數(shù)引用時(shí)使用(如依賴項(xiàng)、子組件 props)。
七、useReducer—— 更復(fù)雜的狀態(tài)邏輯管理
useReducer 更適合處理狀態(tài)變化邏輯復(fù)雜或狀態(tài)結(jié)構(gòu)較大的情況。
用法示例:
import { useReducer } from 'react';
function reducer(state, action) {
switch (action.type) {
case 'increment':
return { count: state.count + 1 };
default:
return state;
}
}
function Counter() {
const [state, dispatch] = useReducer(reducer, { count: 0 });
return (
<button onClick={() => dispatch({ type: 'increment' })}>
{state.count}
</button>
);
}
八、總結(jié)
- 使用
useState管理簡(jiǎn)單狀態(tài),useReducer管理復(fù)雜狀態(tài)。 - 使用
useEffect時(shí)確保清理副作用,避免內(nèi)存泄漏。 - 使用
useMemo和useCallback僅在性能瓶頸時(shí)啟用。 - 將重復(fù)邏輯封裝成自定義 Hook 提高復(fù)用性。
結(jié)語??
React Hook 為函數(shù)組件帶來了強(qiáng)大的功能和靈活性。掌握這些常用 Hook,不僅可以簡(jiǎn)化代碼結(jié)構(gòu),還能提升應(yīng)用的性能與可維護(hù)性。
到此這篇關(guān)于react常用hook的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)react常用hook內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React實(shí)現(xiàn)類似淘寶tab居中切換效果的示例代碼
這篇文章主要介紹了React實(shí)現(xiàn)類似淘寶tab居中切換效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
react-router 路由切換動(dòng)畫的實(shí)現(xiàn)示例
這篇文章主要介紹了react-router 路由切換動(dòng)畫的實(shí)現(xiàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12
解決react?antd?Table組件使用radio單選框?更新選中數(shù)據(jù)不渲染問題
這篇文章主要介紹了解決react?antd?Table組件使用radio單選框?更新選中數(shù)據(jù)不渲染問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
在React框架中實(shí)現(xiàn)一些AngularJS中ng指令的例子
這篇文章主要介紹了在JavaScript的React框架中實(shí)現(xiàn)一些AngularJS指令的例子,React使用Virtual DOM因而與普通的js框架有些不同,需要的朋友可以參考下2016-03-03
react-router v4如何使用history控制路由跳轉(zhuǎn)詳解
這篇文章主要給大家介紹了關(guān)于react-router v4如何使用history控制路由跳轉(zhuǎn)的相關(guān)資料,文中通過示例代碼介紹的的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01

