如何使用 React useEffect 调用加载函数?


我们将使用 React useEffect 钩子来调用我们的加载函数。此钩子允许我们指定一个将在特定组件生命周期事件(例如组件挂载时)运行的函数。通过将我们的加载函数作为依赖项传递,我们确保它将在组件加载或更新时被调用。

React useEffect

useEffect 是 React 中的一个钩子,允许您将组件与外部系统同步。

  • 它在组件渲染后运行,可用于获取数据、更新 DOM 或设置事件监听器。

  • 它接受两个参数:一个包含效果逻辑的函数和一个依赖项列表。

  • 如果需要,效果函数应返回一个清理函数。

  • useEffect 类似于 componentDidMount、componentDidUpdate 和 componentWillUnmount 的组合。

方法

您可以通过将其作为钩子第二个参数中的依赖项传递来使用 React 的 useEffect 钩子调用加载函数。加载函数应在 useEffect 的回调函数内部调用。

示例

import { useEffect } from 'react';
function MyComponent() {
   useEffect(() => {
      loadData();
   }, []); // Pass an empty array to only call the function once on mount.
   
   function loadData() {
      // Fetch data or perform other loading logic here
   }
   
   // ... component render logic
}

您还可以将变量作为依赖项传递给 loadData 函数,以便当依赖项发生变化时,loadData 函数将再次被调用。

import { useEffect } from 'react';

function MyComponent({id}) {
   useEffect(() => {
      loadData(id);
   }, [id]); 
   
   function loadData(id) {
      // Fetch data or perform other loading logic here
   }
   
   // ... component render logic
}

需要注意的是,为了避免无限循环,由加载函数引起的任何状态更新都应在单独的效果中完成。

最终代码

这是一个使用 useEffect 钩子在 React 组件中加载数据的示例 -

App.js

import React, { useEffect, useState } from 'react';
function MyComponent() {
   const [data, setData] = useState(null);
   const [isLoading, setIsLoading] = useState(false);
   useEffect(() => {
      async function fetchData() {
         setIsLoading(true);
         try {
            const response = await fetch('https://jsonplaceholder.typicode.com/users');
            const json = await response.json();
            setData(json);
         } catch (error) {
            console.error(error);
         } finally {
            setIsLoading(false);
         }
      }
      fetchData();
   }, []);
   if (isLoading) {
      return <div style={{ color: 'black' }}>Loading...</div>;
   }
   if (data) {
      return <div style={{ color: 'black' }}>{data.map(item => (<div key={item.id}>
         {item.name}
      </div>))}</div>;
   }
   return <div style={{ color: 'black' }}>No data</div>;
}
export default MyComponent;

在此示例中,MyComponent 组件使用 useEffect 钩子在组件首次渲染时从 API 加载数据 -

  • 该钩子接受两个参数:一个在组件渲染时运行的回调函数,以及一个确定何时应运行效果的依赖项数组。

  • 在本例中,我们将一个空数组作为第二个参数传递,这告诉 React 只在组件首次渲染时运行一次效果。

  • 回调函数 fetchData 首先将 isLoading 状态设置为 true,这会导致组件显示“加载中…”消息。

  • 然后它使用 fetch API 从 API 加载数据并等待响应完成。

  • 然后它解析来自响应的 JSON 数据,并使用解析后的数据设置 data 状态。

  • 如果发生错误,它会将错误记录到控制台。最后,它将 isLoading 状态设置为 false,这会导致组件显示加载的数据或“无数据”消息(如果 API 返回空或错误)。

  • 组件根据当前状态渲染不同的消息:“加载中…”(正在获取数据时)、数据本身(数据已加载时)以及“无数据”(如果 API 返回空或错误)。

  • 请注意,此示例使用 async/await 处理 fetch API 返回的 Promise,如果您使用的是旧版本的 javascript,则可以使用 then() 和 .catch() 方法。

输出

更新于: 2023年2月16日

14K+ 浏览量

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告