React 教程

浏览4950
更新时间2025-08-20

Hooks 是可重用的函数。

当您有需要被多个组件使用的组件逻辑时,我们可以将该逻辑提取到自定义 Hook。

自定义 Hooks 以"use"开头。 示例:useFetch.


建立一个 Hook

在下面的代码中,我们在 Home 组件中获取数据并显示它。

我们将使用 JSONPlaceholder 服务来获取虚假数据。 此服务非常适合在没有现有数据时测试应用程序。

要了解更多信息,请查看 JavaScript Fetch API 部分。

使用 JSONPlaceholder 服务获取虚假的"待办事项"并在页面上显示标题:

实例:

index.js:

import { useState, useEffect } from "react";
import ReactDOM from "react-dom/client";

const Home = () => {
  const [data, setData] = useState(null);

  useEffect(() => {
    fetch("https://jsonplaceholder.typicode.com/todos")
      .then((res) => res.json())
      .then((data) => setData(data));
 }, []);

  return (
    <>
      {data &&
        data.map((item) => {
          return <p key={item.id}>{item.title}</p>;
        })}
    </>
  );
};

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Home />);

运行实例 »

其他组件可能也需要获取逻辑,因此我们将其提取到自定义 Hook 中。

将获取逻辑移动到一个新文件以用作自定义 Hook:

实例:

useFetch.js:

import { useState, useEffect } from "react";

const useFetch = (url) => {
  const [data, setData] = useState(null);

  useEffect(() => {
    fetch(url)
      .then((res) => res.json())
      .then((data) => setData(data));
  }, [url]);

  return [data];
};

export default useFetch;

index.js:

import ReactDOM from "react-dom/client";
import useFetch from "./useFetch";

const Home = () => {
  const [data] = useFetch("https://jsonplaceholder.typicode.com/todos");

  return (
    <>
      {data &&
        data.map((item) => {
          return <p key={item.id}>{item.title}</p>;
        })}
    </>
  );
};

const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Home />);

运行实例 »


示例说明

我们创建了一个名为 useFetch.js 的新文件,其中包含一个名为 useFetch 的函数,其中包含所有 获取数据所需的逻辑。

我们删除了硬编码的 URL,并将其替换为可以传递给自定义 Hook 的 url 变量。

最后,我们从 Hook 中返回数据。

index.js 中,我们正在导入我们的 useFetch Hook 并像使用任何其他 Hook 一样使用它。 这是我们传递 URL 以从中获取数据的地方。

现在我们可以在任何组件中重用这个自定义 Hook 来从任何 URL 获取数据。


相关视频

更多

免费

Web前端开发极速入门
初级Web前端开发极速入门

221947次学习

收藏

免费

前端入门_HTML5
初级前端入门_HTML5

624552次学习

收藏

免费

30分钟学会网站布局
初级30分钟学会网站布局

240718次学习

收藏

免费

CSS视频教程-玉女心经版
初级CSS视频教程-玉女心经版

397459次学习

收藏

免费

独孤九贱(1)_HTML5视频教程
初级独孤九贱(1)_HTML5视频教程

623328次学习

收藏

精品课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时 | 62.5万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时 | 39.7万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时 | 73.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号