react中useEffect函数的详细用法(最新推荐)

 更新时间:2024年06月22日 16:20:00   作者:编程砖家  
useEffect是React中的一个Hook,用于在函数组件中处理副作用(如数据获取、订阅、手动更改 DOM 等),useEffect属于组件的生命周期方法,下面通过本文给大家分享react中useEffect函数的详细用法,感兴趣的朋友跟随小编一起看看吧

1、函数介绍

useEffect 是 React 中的一个 Hook,用于在函数组件中处理副作用(如数据获取、订阅、手动更改 DOM 等)。与类组件中的生命周期方法(如 componentDidMountcomponentDidUpdatecomponentWillUnmount)类似,useEffect 让你在函数组件中完成相同的操作。( from chatGPT)

        简单来说,useEffect属于组件的生命周期方法。在组件不同的生命周期,我们可以通过useEffect函数来控制执行过程。 那么什么是组件的生命周期呢?

2.组件的生命周期

        在 React 中,组件的生命周期分为三个主要阶段:挂载(Mounting)、更新(Updating)和卸载(Unmounting)。挂载和渲染是关键的生命周期阶段,理解它们对于有效地使用 React 至关重要。

2.1 挂载(Mounting)

载是指组件第一次被插入到 DOM 中的过程。挂载阶段包括以下步骤:

  • 构造函数(Constructor):组件的构造函数被调用。如果你在类组件中定义了构造函数,那么它会在组件实例化时首先被调用。
  • getDerivedStateFromProps(静态方法):在初始化和更新期间调用,允许组件基于输入的 props 来更新状态。它是一个静态方法,不能访问组件实例。
  • render:渲染方法被调用。它返回要渲染的元素(通常是 JSX)。
  • componentDidMount:组件已经被挂载到 DOM 中,此时可以执行一些副作用操作,比如数据获取、订阅事件等。

2.2 渲染和更新

渲染(Rendering)

渲染是指组件根据其当前状态和属性生成要显示的元素。每次组件的状态或属性发生变化时,渲染过程都会被触发。渲染阶段包括:

  • render 方法(类组件):被调用以生成虚拟 DOM 结构。
  • 函数组件本身:被调用以生成虚拟 DOM 结构。

在每次状态或属性变化时,组件会重新渲染。React 将对比虚拟 DOM(使用 Diff 算法)并更新实际 DOM 以反映变化。

更新(Updating)

更新是指组件的状态或属性发生变化并重新渲染的过程。更新阶段包括以下步骤:

  • getDerivedStateFromProps(静态方法):同挂载阶段一样,在属性变化时调用。
  • shouldComponentUpdate:决定组件是否应该重新渲染。返回 true 表示重新渲染,返回 false 表示跳过更新。
  • render:渲染方法被调用以生成新的虚拟 DOM 结构。
  • getSnapshotBeforeUpdate:在 DOM 更新之前被调用,返回的值将作为 componentDidUpdate 的第三个参数。
  • componentDidUpdate:组件更新并重新渲染到 DOM 之后调用,可执行副作用操作。

2.3 卸载(Unmounting)

卸载是指组件被移出 DOM 的过程。卸载阶段只包括一个方法:

componentWillUnmount:组件即将卸载时调用,可以在这里执行清理操作,例如取消订阅、清除定时器等。

2.4 总结

  • 挂载:组件第一次被插入到 DOM 中时执行。类组件中使用 componentDidMount,函数组件中使用 useEffect(空依赖数组)。
  • 渲染:每次组件的状态或属性变化时,都会重新生成虚拟 DOM 并更新实际 DOM。
  • 更新:状态或属性变化引起组件重新渲染。类组件中使用 componentDidUpdate,函数组件中使用 useEffect(依赖数组)。
  • 卸载:组件被移出 DOM 时执行。类组件中使用 componentWillUnmount,函数组件中通过 useEffect 的清理函数处理。

3、函数的基本用法

        有了对组件生命周期的认识,那么就可以利用useEffect函数根据组件不同的生命周期阶段来执行不同的方法。比如:

  • 有的方法只希望在执行一次,即在组件挂载的时候执行一次就够了,后面也不需要再次执行
  • 有的方法希望在组件每次渲染(元素有更新)的时候都执行
  • 有的方法希望在某个依赖的变量发生变化时才会执行
  • 有的方法希望在组件卸载(页面退出的)的时候执行

上面的执行过程都都可以通过useEffect方法做到。

3.1 用法示例

import React, { useState, useEffect } from 'react';
function ExampleComponent() {
  const [count, setCount] = useState(0);
  useEffect(() => {
    // 这里的代码相当于 componentDidMount 和 componentDidUpdate
    document.title = `You clicked ${count} times`;
    // 如果需要清理,可以返回一个函数
    return () => {
      // 这里的代码相当于 componentWillUnmount
      console.log('Cleaning up...');
    };
  }, [count]); // 依赖数组
  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>Click me</button>
    </div>
  );
}
export default ExampleComponent;

3.2 用法说明

副作用的执行

  • useEffect 的第一个参数是一个函数,它在组件渲染后执行。可以在这个函数内进行副作用操作。
  • 如果需要清理副作用,可以在这个函数中返回一个函数,这个返回的函数会在组件卸载或副作用重新执行前调用。

依赖数组

  • useEffect 的第二个参数是一个依赖数组(可以依赖多个变量),表示副作用依赖的变量。当依赖数组中的任何一个变量发生变化时,副作用函数会重新执行。
  • 如果依赖数组为空([]),副作用函数只会在组件挂载和卸载时执行一次,类似于 componentDidMountcomponentWillUnmount
  • 如果不传依赖数组,副作用函数会在每次组件渲染后执行,类似于 componentDidUpdate

3.3 使用规则

  • 在组件顶层调用:只能在 React 函数组件或自定义 Hook 的顶层调用 useEffect,不要在循环、条件或嵌套函数中调用。
  • 依赖数组:确保正确设置依赖数组,以避免不必要的副作用执行或缺少必要的更新。

到此这篇关于react中useEffect函数的详细用法的文章就介绍到这了,更多相关react useEffect函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • react中常见hook的使用方式

    react中常见hook的使用方式

    这篇文章主要介绍了react中常见hook的使用方式与区别,帮助大家更好的理解和学习使用react,感兴趣的朋友可以了解下
    2021-04-04
  • 如何在React项目中使用AntDesign

    如何在React项目中使用AntDesign

    我们在后台管理系统React项目开发中会有Table表格、Form表单、List列表、Button按钮等组件,这个时候我们可以使用AntDesign来减少开发中不必要的样式问题,本文就介绍了eact项目中使用AntDesign,感兴趣的可以了解一下
    2022-04-04
  • React Native中导航组件react-navigation跨tab路由处理详解

    React Native中导航组件react-navigation跨tab路由处理详解

    这篇文章主要给大家介绍了关于React Native中导航组件react-navigation跨tab路由处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-10-10
  • 关于react-router-dom路由入门教程

    关于react-router-dom路由入门教程

    这篇文章主要介绍了关于react-router-dom路由入门教程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • 渐进式源码解析React更新流程驱动

    渐进式源码解析React更新流程驱动

    这篇文章主要为大家介绍了渐进式源码解析React更新流程驱动详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 浅析React中的受控组件和非受控组件

    浅析React中的受控组件和非受控组件

    具体来说这是一种react非受控组件,其状态是在input的react内部控制,不受调用者控制。可以使用受控组件来实现。下面就说说这个React中的受控组件与非受控组件的相关知识,感兴趣的朋友一起看看吧
    2021-05-05
  • React Native性能优化红宝书方案详解

    React Native性能优化红宝书方案详解

    React Native 是Facebook在React.js Conf2015推出的开源框架,使用React和应用平台的原生功能来构建Android和iOS应用,这篇文章主要介绍了React Native性能优化红宝书,需要的朋友可以参考下
    2024-06-06
  • React冒泡和阻止冒泡的应用详解

    React冒泡和阻止冒泡的应用详解

    这篇文章主要介绍了React冒泡和阻止冒泡的应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • react如何快速设置文件路径别名

    react如何快速设置文件路径别名

    React是用于构建用户界面的JavaScript库, 起源于Facebook的内部项目,这篇文章主要介绍了react如何快速设置文件路径别名,需要的朋友可以参考下
    2021-04-04
  • React Server Component混合式渲染问题详解

    React Server Component混合式渲染问题详解

    React 官方对 Server Comopnent 是这样介绍的: zero-bundle-size React Server Components,这篇文章主要介绍了React Server Component: 混合式渲染,需要的朋友可以参考下
    2022-12-12

最新评论