一、引言

在现代 React 开发领域,Hooks 已成为不可或缺的一部分,赋予函数组件强大功能,使其能胜任复杂任务。本文将全面剖析 React Hooks,助您深入理解并熟练运用。

二、React Hooks 是什么

(一)Hooks 出现的背景

早期 React 主要依赖类组件,其通过this.state管理状态及生命周期方法处理逻辑,但存在this指向复杂、代码复用性欠佳等问题。Hooks 的诞生有效解决了这些困扰,让开发者能在函数组件中便捷地运用状态及其他 React 特性。

(二)基本的 Hooks

1.useState
useState常用于在函数组件中引入状态,示例如下:

import React, { useState } from 'react';
function Counter() {
  const [count, setCount] = useState(0);
  return (
    <div>
      <p>Count: {count}</p>
      <button onClick={() => setCount(count + 1)}>Increment</button>
    </div>
  );
}

它接受初始值,返回包含当前状态值与更新状态函数的数组。

2.useEffect
useEffect用于处理函数组件中的副作用,如数据获取、订阅操作、DOM 修改等,例如:

import React, { useState, useEffect } from 'react';
function Example() {
  const [count, setCount] = useState(0);
  useEffect(() => {
    document.title = `You clicked ${count} times`;
  }, [count]);
  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>Click me</button>
    </div>
  );
}

其第一个参数为执行副作用的函数,第二个参数是依赖项数组,数组内值变化时该函数会重新执行。

三、Hooks 的规则

(一)只能在顶层调用 Hooks

Hooks 必须在函数组件的顶层进行调用,这是因为 React 依靠 Hooks 的调用顺序来确定它们与组件实例的对应关系。若在循环、条件语句或嵌套函数中调用,可能导致调用顺序混乱,进而引发错误。

(二)只能在 React 函数组件或者自定义 Hook 中调用 Hooks

此规则确保了 Hooks 能与 React 组件的生命周期及渲染逻辑正确关联,保障组件行为符合预期。

四、高级 Hooks 用法

(一)自定义 Hooks

自定义 Hooks 可将可复用的逻辑提取出来,形成独立函数。例如useWindowWidth自定义 Hook:

import { useState, useEffect } from 'react';
function useWindowWidth() {
  const [width, setWidth] = useState(window.innerWidth);
  useEffect(() => {
    const handleResize = () => setWidth(window.innerWidth);
    window.addEventListener('resize', handleResize);
    return () => window.removeEventListener('resize', handleResize);
  }, []);
  return width;
}
11-17 21:14