React组件生命周期

一张图解释
在这里插入图片描述

React 类组件生命周期方法

React 类组件的生命周期可以分为三个主要阶段:

挂载(Mounting)

更新(Updating)

卸载(Unmounting)

  1. 挂载阶段
    在组件实例被创建并插入到 DOM 中时调用。
  • constructor(): 构造函数,初始化 state 和绑定方法。
  • static getDerivedStateFromProps(props, state): 在调用 render 方法之前调用,并且在- 初始挂载及后续更新时都会被调用。它应该返回一个对象来更新 state,如果返回 null 则不更新任何内容。
  • render(): 必须的方法,返回要渲染的内容。
  • componentDidMount(): 在组件挂载后(插入 DOM 树中)立即调用。这里适合发送网络请求或订阅。
class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
    console.log('Constructor');
  }

  static getDerivedStateFromProps(props, state) {
    console.log('getDerivedStateFromProps');
    return null;
  }

  componentDidMount() {
    console.log('componentDidMount');
  }

  render() {
    console.log('Render');
    return <div>{this.state.count}</div>;
  }
}


  1. 更新阶段
    当组件的 props 或 state 发生变化时会触发更新。
  • static getDerivedStateFromProps(props, state): 同上。
  • shouldComponentUpdate(nextProps, nextState): 决定组件是否重新渲染,返回 true(默认)或 false。
  • render(): 同上。
  • getSnapshotBeforeUpdate(prevProps, prevState): 在最近一次渲染输出(提交到 DOM 节点)之前调用。它使得组件能在发生更改之前从 DOM 中捕获一些信息(例如,滚动位置)。
  • componentDidUpdate(prevProps, prevState, snapshot): 在组件更新后被调用。这里可以做一些基于 DOM 操作的工作,更新后的 state 和 props 可以通过参数访问。
class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
  }

  static getDerivedStateFromProps(props, state) {
    console.log('getDerivedStateFromProps');
    return null;
  }

  shouldComponentUpdate(nextProps, nextState) {
    console.log('shouldComponentUpdate');
    return true;
  }

  getSnapshotBeforeUpdate(prevProps, prevState) {
    console.log('getSnapshotBeforeUpdate');
    return null;
  }

  componentDidUpdate(prevProps, prevState, snapshot) {
    console.log('componentDidUpdate');
  }

  render() {
    console.log('Render');
    return <div>{this.state.count}</div>;
  }
}


  1. 卸载阶段
    在组件从 DOM 中移除时调用。
  • componentWillUnmount(): 在组件卸载及销毁之前直接调用。在这里可以执行必要的清理操作,例如清除定时器、取消网络请求或清理在 componentDidMount 中创建的订阅。
class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
  }

  componentWillUnmount() {
    console.log('componentWillUnmount');
  }

  render() {
    return <div>{this.state.count}</div>;
  }
}


React Hooks 生命周期

在函数组件中使用 React Hooks(如 useEffect)来模拟类组件的生命周期方法。

import React, { useState, useEffect } from 'react';

const MyComponent = () => {
  const [count, setCount] = useState(0);

  // componentDidMount 和 componentDidUpdate
  useEffect(() => {
    console.log('Component did mount or update');
    return () => {
      // componentWillUnmount
      console.log('Component will unmount');
    };
  }, [count]); // 依赖数组,count 变化时触发 useEffect

  return <div>{count}</div>;
};


总结

  • 类组件有明确的生命周期方法,用于在组件的不同阶段执行特定操作。
  • 函数组件使用 Hooks (useEffect) 来处理副作用,模拟类组件的生命周期方法。
  • useEffect 可以根据依赖数组来决定副作用的执行时机(挂载、更新、卸载)。

  • 但组件生命周期
  • 父子组件生命周期,和Vue的一样
  • 19
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值