react的生命周期函数

生命周期钩子函数:

生命周期钩子函数应用于有状态组件中,有些只运行一次,有些需要运行多次

创建组件时候需要执行的钩子函数(按照执行顺序):

constructor()-------->componentWillMount()-->|render()------------>|componentDidMount()

1、constructor:不是react的方法,是es6的方法,可以在react中使用,调用当前组件的父级,也可以在函数中设置当前组件所需要的状态state;

2、componentWillMount:当前组件即将生成,可以在该函数中修改状态state;

3、render:创建虚拟dom,更新dom,加载配套子组件(并不是加载所有子组件)

4、componentDidMount:组件渲染完毕,执行该函数,在该函数中一定不能更新状态,因为一旦更新状态,就会进行重新render,又会执行该函数,会陷入死循环。

组件发生变化,触发更新的钩子函数:

组件更新的时候触发的相关函数(按照执行顺序):

  componentWillReceiveProps(nextProps){}---------->组件发生改变触发
  shouldComponentUpdate(nextProps,nextState){}     --------->控制组件是否重新渲染
  componentWillUpdate(nextProps,nextState){}       --------->进入重新渲染流程
  render(){}                    --------->更新相关组件
  componentDidUpdate(){}        --------->组件渲染完毕

componentWillReceiveProps:组件将要接收属性,执行该方法

shouldComponentUpdate:是否要更新当前组件,非常好用的方法,react中唯一一个控制组件是否渲染的方法(根据条件判断),方法返回false不进行到下一个阶段,返回为true,则进行到下一个阶段

componentWillUpdate:组件进入到渲染流程,即将更新

render:更新当前相关的子组件,渲染完毕后走到下一步

componentDidUpdate:渲染完毕执行的方法

 

 

 

 

 

 

 

 

 

 

 

 

 

 

React中的生命周期函数指的是在组件的生命周期中会被自动调用的一些特定函数。以下是React的常见生命周期函数: 1. constructor(props): 组件创建时调用的函数,用于初始化状态和绑定方法。 2. static getDerivedStateFromProps(props, state): 组件创建和更新时调用的静态函数,在render之前调用。它接收props和state作为参数,返回一个对象来更新state,或者返回null。 3. render(): 渲染函数,用于返回组件的JSX结构。 4. componentDidMount(): 组件挂载后调用的函数,通常用于进行DOM操作、网络请求等副作用操作。 5. shouldComponentUpdate(nextProps, nextState): 组件更新前调用的函数,用于判断是否需要重新渲染组件。默认情况下,每次state或props更新都会重新渲染组件。 6. getSnapshotBeforeUpdate(prevProps, prevState): 组件更新前调用的函数,在render之后、组件DOM更新之前调用。它接收prevProps和prevState作为参数,返回一个值,将作为第三个参数传递给componentDidUpdate()函数。 7. componentDidUpdate(prevProps, prevState, snapshot): 组件更新后调用的函数,通常用于进行DOM操作、网络请求等副作用操作。 8. componentWillUnmount(): 组件卸载前调用的函数,用于清理定时器、取消网络请求等操作。 这些生命周期函数在组件的不同阶段会被自动调用,开发者可以在相应的生命周期函数中执行特定的操作,以实现组件的逻辑和交互效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值