react生命周期

学无止境,望君把握时间

react的生命周期中一共有4个阶段,分别是:初始阶段,运行中阶段,销毁阶段和错误处理阶段

初始化阶段:

在组件初始化阶段会执行,一共有5个钩子函数:
1.constructor
2.static getDerivedStateFromProps()
3.ComponentWillMount() / UNSAFE_ComponentWillMount()
4.render()
5.ComponentDidMount()
1.constructor(props)
React组件的构造函数在挂载之前被调用.在实现react.Component构造函数时,
需要在添加其它内容前,加上super(props),用来将父组件传来的props绑定到
这个类中,使用this.props可以调用。
官方建议不要在`constructor`引入任何具有副作用和订阅功能的代码,
这些应当使用`componentDidMount()``constructor`中应当做些初始化的动作,如:初始化`state`,将事件处理函数绑定
到类实例上,但也不要使用`setState()`。如果没有必要初始化state或绑定方法,
则不需要构造`constructor`,或者把这个组件换成纯函数写法。

当然也可以利用`props`初始化`state`,在之后修改`state`不会对`props`造成任何修改,
但仍然建议大家提升状态到父组件中,或使用`redux`统一进行状态管理。

constructor(props){
   super(props)
   this.state = {
       name : props.name
   }
}
static getDerivedStateMount(nextProps,prevState)
getDerivedStateMount()是react16.3之后新增的,在组件实例化后,和接受新的props
后被调用。他必须返回一个对象来更新状态,或者返回null表示props不需要任何state更新
如果是由于父组件的`props`更改,所带来的重新渲染,也会触发此方法。
调用`steState()`不会触发`getDerivedStateFromProps()`。
之前这里都是使用`constructor`+`componentWillRecieveProps`完成相同的功能的

ComponentWillMount() / UNAFE_ComponentWillMount()
componentWillMount()`将在React未来版本(官方说法 17.0)中被弃用。
`UNSAFE_componentWillMount()`在组件挂载前被调用,在这个方法中调用
`setState()`不会起作用,是由于他在`render()`前被调用。

为了避免副作用和其他的订阅,官方都建议使用`componentDidMount()`代替。
这个方法是用于在服务器渲染上的唯一方法。这个方法因为是在渲染之前被调用,也是惟一一个
可以直接同步修改state的地方。
4.render ():是必须的,当他被调用时,他将计算`this.props``this.state`,并返回以
下一种类型:
1.React元素。通过jsx创建,既可以是dom元素,也可以是用户自定义的组件。
2.字符串或数字。他们将会以文本节点形式渲染到dom中.
3.Portals。react 16版本中提出的新的解决方案,可以使组件脱离父组件层级直接挂载在
DOM树的任何位置。
4.null, 什么也不渲染。
5.布尔值。也是什么都不渲染。

render()`方法必须是一个纯函数,他不应该改变`state`,也不能直接和浏览器进行交互,
应该将事件放在其他生命周期函数中。 
如果`shouldComponentUpdate()`返回`false`,`render()`不会被调用。
5.componentDidMount()
componentDidMount`在组件被装配后立即调用。初始化使得DOM节点应该进行到这里。
`通常在这里进行ajax请求`
如果要初始化第三方的dom库,也在这里进行初始化。只有到这里才能获取到真实的dom.

运行中阶段:

6.componentWillReceiveProps()/UNSAFE_componentWillReceiveProps(nextProps)
官方建议使用`getDerivedStateFromProps`函数代替`componentWillReceiveProps`。
当组件挂载后,接收到新的`props`后会被调用。如果需要更新`state`来响应`props`的更改,
则可以进行`this.props``nextProps`的比较,并在此方法中使用`this.setState()`。
如果父组件会让这个组件重新渲染,即使props没有改变,也会调用这个方法。
react不会在组件初始化props时调用这个方法。调用this.setState也不会触发。
7.shouldComponentUpdate(nextProps, nextState)
调用`shouldComponentUpdate`使React知道,组件的输出是否受`state``props`的影响。默
认每个状态的更改都会重新渲染,大多数情况下应该保持这个默认行为。
在渲染新的`props``state`前,`shouldComponentUpdate`会被调用。默认为`true`。这个
方法不会在初始化时被调用,也不会在`forceUpdate()`时被调用。返回`false`不会阻止子组
件在`state`更改时重新渲染。

如果`shouldComponentUpdate()`返回`false``componentWillUpdate`,`render``componentDidUpdate`不会被调用。
官方并不建议在`shouldComponentUpdate()`中进行深度查询或使用`JSON.stringify()`,
他效率非常低,并且损伤性能。
8.UNSAFE_componentWillUpdate(nextProps, nextState)
在渲染新的`state``props`时,`UNSAFE_componentWillUpdate`会被调用,将此作为在
更新发生之前进行准备的机会。这个方法不会在初始化时被调用。
不能在这里使用this.setState()*,也不能做会触发视图更新的操作。如果需要更新`state``props`,调用`getDerivedStateFromProps`
9.getSnapshotBeforeUpdate()
在react `render()`后的输出被渲染到DOM之前被调用。它使您的组件能够在它们被潜在更改之前
捕获当前值(如滚动位置)。


这个生命周期返回的任何值都将作为参数传递给componentDidUpdate()。
10.componentDidUpdate(prevProps, prevState, snapshot)
在更新发生之后立即调用componentDidUpdate().此方法不用于初始渲染。当组件更新时,
将此作为一个机会来操作DOM。只要您将当前的props与以前的props进行比较(例如,如果props
没有改变,则可能不需要网络请求),这也是做网络请求的好地方
如果组件实现`getSnapshotBeforeUpdate()`生命周期,则它返回的值将作为第三个“快照”
参数传递给`componentDidUpdate()`。否则,这个参数是`undefined`

销毁阶段:

11.componentWillUnmount()
在组件被卸载并销毁之前立即被调用。在此方法中执行任何必要的清理,例如使定时器无效,
取消网络请求或清理在`componentDidMount`中创建的任何监听。

错误处理阶段:

12.componentDidCatch(error, info)
错误边界是React组件,可以在其子组件树中的任何位置捕获JavaScript错误,记录这些错误并
显示回退UI,而不是崩溃的组件树。错误边界在渲染期间,生命周期方法以及整个树下的构造函
数中捕获错误。

如果类组件定义了此生命周期方法,则它将成错误边界。在它中调用`setState()`可以让你在下
面的树中捕获未处理的JavaScript错误,并显示一个后备UI。只能使用错误边界从意外异常中恢
复; 不要试图将它们用于控制流程。

错误边界只会捕获树中下面组件中的错误。错误边界本身不能捕获错误。

总结:react生命周期一共分4个阶段(其实是三个:初始化阶段,运行中阶段,销毁阶段)初始化阶段有五个钩子函数,运行中有7个钩子函数,销毁和错误处理分别每个有1个钩子函数。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值