欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react常用hook的實(shí)現(xiàn)示例

 更新時(shí)間:2025年08月25日 09:47:56   作者:Aphasia  
本文主要介紹了react常用hook的實(shí)現(xiàn)示例,提供狀態(tài)管理、副作用處理、引用、跨組件共享及性能優(yōu)化功能,具有一定的參考價(jià)值,感興趣的可以了解一下

引言??

自 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ā)更新的場景。

四、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)化性能,但請勿濫用。

六、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 管理簡單狀態(tài),useReducer 管理復(fù)雜狀態(tài)。
  • 使用 useEffect 時(shí)確保清理副作用,避免內(nèi)存泄漏。
  • 使用 useMemouseCallback 僅在性能瓶頸時(shí)啟用。
  • 將重復(fù)邏輯封裝成自定義 Hook 提高復(fù)用性。

結(jié)語??

React Hook 為函數(shù)組件帶來了強(qiáng)大的功能和靈活性。掌握這些常用 Hook,不僅可以簡化代碼結(jié)構(gòu),還能提升應(yīng)用的性能與可維護(hù)性。

到此這篇關(guān)于react常用hook的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)react常用hook內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React實(shí)現(xiàn)類似淘寶tab居中切換效果的示例代碼

    React實(shí)現(xiàn)類似淘寶tab居中切換效果的示例代碼

    這篇文章主要介紹了React實(shí)現(xiàn)類似淘寶tab居中切換效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 淺談React組件在什么情況下會(huì)重新渲染

    淺談React組件在什么情況下會(huì)重新渲染

    當(dāng)我們使用React編寫組件時(shí),組件的重新渲染是一個(gè)重要的概念,本文主要介紹了React組件在什么情況下會(huì)重新渲染,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • react-router 路由切換動(dòng)畫的實(shí)現(xiàn)示例

    react-router 路由切換動(dòng)畫的實(shí)現(xiàn)示例

    這篇文章主要介紹了react-router 路由切換動(dòng)畫的實(shí)現(xiàn)示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • React?Streaming?SSR原理示例深入解析

    React?Streaming?SSR原理示例深入解析

    這篇文章主要為大家介紹了React?Streaming?SSR原理示例深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 解決react?antd?Table組件使用radio單選框?更新選中數(shù)據(jù)不渲染問題

    解決react?antd?Table組件使用radio單選框?更新選中數(shù)據(jù)不渲染問題

    這篇文章主要介紹了解決react?antd?Table組件使用radio單選框?更新選中數(shù)據(jù)不渲染問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 在React框架中實(shí)現(xiàn)一些AngularJS中ng指令的例子

    在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)詳解

    react-router v4如何使用history控制路由跳轉(zhuǎn)詳解

    這篇文章主要給大家介紹了關(guān)于react-router v4如何使用history控制路由跳轉(zhuǎn)的相關(guān)資料,文中通過示例代碼介紹的的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • 一文帶你搞懂React中的useReducer

    一文帶你搞懂React中的useReducer

    useReducer 是除useState之外另一個(gè)與狀態(tài)管理相關(guān)的 hook,這篇文章主要為大家介紹了useReducer應(yīng)用的相關(guān)知識,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • 詳解react-native-fs插件的使用以及遇到的坑

    詳解react-native-fs插件的使用以及遇到的坑

    本篇文章主要介紹了react-native-fs插件的使用以及遇到的坑,詳細(xì)的介紹了react-native-fs安裝使用,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • React中常用的一些鉤子函數(shù)總結(jié)

    React中常用的一些鉤子函數(shù)總結(jié)

    這篇文章給大家總結(jié)了React中常用的一些鉤子函數(shù),文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01

最新評論