React-新的生命周期

组件生命周期的三个阶段

  1. Mounting(加载阶段)
  2. Updating(更新阶段)
  3. Unmounting(卸载阶段)

旧的生命周期

图片描述

Mounting(加载阶段:涉及6个钩子函数)

constructor()javascript

加载的时候调用一次,能够初始化state复制代码

getDefaultProps()java

设置默认的props,也能够用dufaultProps设置组件的默认属性。复制代码

getInitialState()react

初始化state,能够直接在constructor中定义this.state复制代码

componentWillMount()算法

组件加载时只调用,之后组件更新不调用,整个生命周期只调用一次,此时能够修改state复制代码

render()sql

react最重要的步骤,建立虚拟dom,进行diff算法,更新dom树都在此进行复制代码

componentDidMount()bash

组件渲染以后调用,只调用一次复制代码

Updating(更新阶段:涉及5个钩子函数)

componentWillReceivePorps(nextProps)dom

组件加载时不调用,组件接受新的props时调用复制代码

shouldComponentUpdate(nextProps, nextState)函数

组件接收到新的props或者state时调用,return true就会更新dom(使用diff算法更新),return false能阻止更新(不调用render)复制代码

componentWillUpdata(nextProps, nextState)ui

组件加载时不调用,只有在组件将要更新时才调用,此时能够修改state复制代码

render()this

react最重要的步骤,建立虚拟dom,进行diff算法,更新dom树都在此进行复制代码

componentDidUpdate()

组件加载时不调用,组件更新完成后调用复制代码

Unmounting(卸载阶段:涉及1个钩子函数)

componentWillUnmount()

组件渲染以后调用,只调用一次
复制代码

组件的基本写法

import React, { Component } from 'react'

export default class OldReactComponent extends Component {
    constructor(props) {
        super(props)
        // getDefaultProps:接收初始props
        // getInitialState:初始化state
    }
    state = {

    }
    componentWillMount() { // 组件挂载前触发

    }
    render() {
        return (
            <h2>Old React.Component</h2>
        )
    }
    componentDidMount() { // 组件挂载后触发

    }
    componentWillReceivePorps(nextProps) { // 接收到新的props时触发

    }
    shouldComponentUpdate(nextProps, nextState) { // 组件Props或者state改变时触发,true:更新,false:不更新
        return true
    }
    componentWillUpdate(nextProps, nextState) { // 组件更新前触发

    }
    componentDidUpdate() { // 组件更新后触发

    }
    componentWillUnmount() { // 组件卸载时触发

    }
}复制代码

新的生命周期

Mounting(加载阶段:涉及4个钩子函数)

constructor()

加载的时候调用一次,能够初始化state复制代码

static getDerivedStateFromProps(props, state)

组件每次被rerender的时候,包括在组件构建以后(虚拟dom以后,实际dom挂载以前),每次获取新的props或state以后;每次接收新的props以后都会返回一个对象做为新的state,返回null则说明不须要更新state;配合componentDidUpdate,能够覆盖componentWillReceiveProps的全部用法复制代码

render()

react最重要的步骤,建立虚拟dom,进行diff算法,更新dom树都在此进行复制代码

componentDidMount()

组件渲染以后调用,只调用一次复制代码

Updating(更新阶段:涉及5个钩子函数)

static getDerivedStateFromProps(props, state)

组件每次被rerender的时候,包括在组件构建以后(虚拟dom以后,实际dom挂载以前),每次获取新的props或state以后;每次接收新的props以后都会返回一个对象做为新的state,返回null则说明不须要更新state;配合componentDidUpdate,能够覆盖componentWillReceiveProps的全部用法复制代码

shouldComponentUpdate(nextProps, nextState)

组件接收到新的props或者state时调用,return true就会更新dom(使用diff算法更新),return false能阻止更新(不调用render)复制代码

render()

react最重要的步骤,建立虚拟dom,进行diff算法,更新dom树都在此进行复制代码

getSnapshotBeforeUpdate(prevProps, prevState)

触发时间: update发生的时候,在render以后,在组件dom渲染以前;返回一个值,做为componentDidUpdate的第三个参数;配合componentDidUpdate, 能够覆盖componentWillUpdate的全部用法复制代码

componentDidUpdate()

组件加载时不调用,组件更新完成后调用复制代码

Unmounting(卸载阶段:涉及1个钩子函数)

组件渲染以后调用,只调用一次复制代码

Error Handling(错误处理)

componentDidCatch(error,info)

任何一处的javascript报错会触发复制代码

组件的基本写法

import React, { Component } from 'react'

export default class NewReactComponent extends Component {
    constructor(props) {
        super(props)
        // getDefaultProps:接收初始props
        // getInitialState:初始化state
    }
    state = {

    }
    static getDerivedStateFromProps(props, state) { // 组件每次被rerender的时候,包括在组件构建以后(虚拟dom以后,实际dom挂载以前),每次获取新的props或state以后;;每次接收新的props以后都会返回一个对象做为新的state,返回null则说明不须要更新state
        return state
    }
    componentDidCatch(error, info) { // 获取到javascript错误

    }
    render() {
        return (
            <h2>New React.Component</h2>
        )
    }
    componentDidMount() { // 挂载后
        
    }   
    shouldComponentUpdate(nextProps, nextState) { // 组件Props或者state改变时触发,true:更新,false:不更新
        return true
    }
    getSnapshotBeforeUpdate(prevProps, prevState) { // 组件更新前触发

    }
    componentDidUpdate() { // 组件更新后触发

    }
    componentWillUnmount() { // 组件卸载时触发

    }
}复制代码

总结

旧的生命周期
图片描述
新的生命周期
图片描述

  1. React16新的生命周期弃用了componentWillMount、componentWillReceivePorps,componentWillUpdate
  2. 新增了getDerivedStateFromProps、getSnapshotBeforeUpdate来代替弃用的三个钩子函数(componentWillMount、componentWillReceivePorps,componentWillUpdate)
  3. React16并无删除这三个钩子函数,可是不能和新增的钩子函数(getDerivedStateFromProps、getSnapshotBeforeUpdate)混用,React17将会删除componentWillMount、componentWillReceivePorps,componentWillUpdate
  4. 新增了对错误的处理(componentDidCatch)
相关文章
相关标签/搜索