React中的生命周期用法详解

 更新时间:2025年03月12日 09:28:16   作者:酒江  
这篇文章主要介绍了React中的生命周期用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

React中的生命周期

在 React 中,组件的生命周期是指从组件创建到销毁的整个过程。

React 的生命周期可以分为三大类:挂载(Mounting)、更新(Updating)、卸载(Unmounting)。

这些生命周期方法提供了在组件的不同阶段执行代码的机会。

1. 挂载阶段(Mounting)

当组件被创建并插入 DOM 时,会依次触发以下生命周期方法:

  • constructor(props)

构造函数,在组件实例化时调用。用于初始化组件的 state 或绑定事件处理函数。

constructor(props) {
  super(props);
  this.state = { count: 0 };
}
  • static getDerivedStateFromProps(nextProps, nextState)

在每次渲染之前调用,无论是初始化渲染还是后续更新。此方法返回一个对象来更新 state,或者返回 null 表示不更新 state。

static getDerivedStateFromProps(nextProps, nextState) {
  if (nextProps.value !== nextState.value) {
    return { derivedValue: nextProps.value };
  }
  return null;
}
  • render()

这个方法是必需的,它返回组件的 JSX 结构,用于渲染 UI。

  • componentDidMount()

在组件挂载后调用。通常用于进行网络请求或其他需要在 DOM 更新后执行的操作。

componentDidMount() {
  console.log("Component mounted");
}

2. 更新阶段(Updating)

当组件的 state 或 props 发生变化时,组件会进入更新阶段。更新阶段包括以下生命周期方法:

  • static getDerivedStateFromProps(nextProps, nextState)

更新阶段同样会调用此方法。它在每次接收到新的 props 时调用,返回一个对象来更新 state 或返回 null。

  • shouldComponentUpdate(nextProps, nextState)

在组件更新之前调用,返回 truefalse,用于优化性能,避免不必要的渲染。

shouldComponentUpdate(nextProps, nextState) {
  return nextState.count !== this.state.count;
}
  • render()

更新阶段与挂载阶段一样,render() 方法会被调用,返回新的 UI。

  • getSnapshotBeforeUpdate(prevProps, prevState)

在 React 更新 DOM 之前调用,返回一个值作为 componentDidUpdate 方法的第三个参数,通常用于获取一些 DOM 信息(如滚动位置)。

getSnapshotBeforeUpdate(prevProps, prevState) {
  return prevState.scrollPosition;
}
  • componentDidUpdate(prevProps, prevState, snapshot)

在组件更新后调用。可以通过比较前后 props 或 state,来执行额外的操作。

componentDidUpdate(prevProps, prevState, snapshot) {
  if (this.state.count !== prevState.count) {
    console.log("Count changed");
  }
}

3. 卸载阶段(Unmounting)

当组件从 DOM 中卸载时,会调用以下生命周期方法:

  • componentWillUnmount()

在组件卸载之前调用,用于清理定时器、取消网络请求或解绑事件监听等。

componentWillUnmount() {
  console.log("Component will unmount");
}

4. 错误处理阶段(Error Handling)(React 16+ 新增)

React 16 引入了错误边界机制,用于捕获渲染过程中的 JavaScript 错误,并渲染一个备用的 UI。

  • static getDerivedStateFromError(error)

捕获子组件的错误,并更新 state 以显示备用 UI。

static getDerivedStateFromError(error) {
  return { hasError: true };
}
  • componentDidCatch(error, info)

捕获并处理错误,通常用于日志记录或其他后续操作。

componentDidCatch(error, info) {
  logErrorToMyService(error, info);
}

总结

React 组件生命周期方法主要分为三个阶段:挂载(Mounting)、更新(Updating)、卸载(Unmounting),以及错误处理阶段。

它们提供了不同的时机让开发者在组件的生命周期内执行特定操作,比如初始化状态、更新 UI、执行副作用操作等。

常见生命周期方法:

阶段方法
挂载constructor, getDerivedStateFromProps, render, componentDidMount
更新getDerivedStateFromProps, shouldComponentUpdate, render, getSnapshotBeforeUpdate, componentDidUpdate
卸载componentWillUnmount
错误处理getDerivedStateFromError, componentDidCatch

随着 React 16.3 后引入的 Hooks,一些传统的类组件生命周期方法被替代或改进,但在类组件中,生命周期方法仍然是管理组件行为的核心。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于React中使用window.print()出现页面无响应问题解决记录

    关于React中使用window.print()出现页面无响应问题解决记录

    这篇文章主要介绍了React中使用window.print()出现页面无响应问题解决记录,首先问题原因可能是操作了document但是并未进行销毁(可能是),具体问题解决思路参考下本文吧
    2021-11-11
  • Redis数据结构面试高频问题解析

    Redis数据结构面试高频问题解析

    这篇文章主要为大家介绍了Redis数据结构高频面试问题解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • 插件化机制优雅封装你的hook请求使用方式

    插件化机制优雅封装你的hook请求使用方式

    这篇文章主要为大家介绍了插件化机制优雅封装你的hook请求使用方式示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • React函数式组件Hook中的useEffect函数的详细解析

    React函数式组件Hook中的useEffect函数的详细解析

    useEffect是react v16.8新引入的特性。我们可以把useEffect hook看作是componentDidMount、componentDidUpdate、componentWillUnmounrt三个函数的组合
    2022-10-10
  • React使用ref方法与场景介绍

    React使用ref方法与场景介绍

    这篇文章主要介绍了React使用ref方法与场景,React支持给任意组件添加特殊属性。ref属性接受一个回调函数,它在组件被加载或卸载时会立即执行
    2022-10-10
  • React中使用UEditor百度富文本的方法

    React中使用UEditor百度富文本的方法

    这篇文章主要介绍了React中使用UEditor的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • React实现虚拟滚动的三种思路详解

    React实现虚拟滚动的三种思路详解

    在​​web​​开发的过程中,或多或少都会遇到大列表渲染的场景,为了解决大列表造成的渲染压力,便出现了虚拟滚动技术,本文主要介绍虚拟滚动的三种思路,希望对大家有所帮助
    2024-04-04
  • React拆分窗格组件的两种方法

    React拆分窗格组件的两种方法

    这篇文章主要介绍了React拆分窗格组件的两种方法,使用第三方库react-split-pane适用于快速实现拆分窗格功能,并且对功能和样式的要求较为简单的场景,本文结合示例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • react-router v4如何使用history控制路由跳转详解

    react-router v4如何使用history控制路由跳转详解

    这篇文章主要给大家介绍了关于react-router v4如何使用history控制路由跳转的相关资料,文中通过示例代码介绍的的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • react封装全局弹框的方法

    react封装全局弹框的方法

    这篇文章主要为大家详细介绍了react封装全局弹框的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10

最新评论