zoukankan      html  css  js  c++  java
  • React生命周期详解

    首先当组件第一次渲染的时候会执行哪些生命周期函数?

    constructor--->componentWillMount--->render--->componentDidMount

    constructor:

    初始化

    当前生命周期函数可以用来定义当前组件所需要的一些状态

    当前生命周期里面必须要写super如果不写会报错/或者this的指向可能发生改变

    如果在super和constructor中没有传递props这个参数的话是访问不到this.props属性的,反之可以进行访问

    componentWillMount:

    组件挂载前:

    在当前生命周期函数里面可以访问到props属性,在这里可以接受到外部属性,同时可以将外部属性转换为内部属性

    在当前生命周期函数里面不需要调用setState,因为当前函数执行完毕以后就会执行render函数

    render:

    1、render函数什么时候会执行?

    a、当this.props/this.state发生改变的时候render函数就会去执行。

    2、this.props/this.state发生改变的时候会执行哪些生命周期函数

    this.state:

    shouldComponentUpdate--->componentWillUpdate--->render--->componentDidUpdate

    this.props

    componentWillReceiveProps--->shouldComponentUpdate--->componentWillUpdate--->render--->componentDidUpdate

    2、render函数执行的时候会将虚拟DOM和数据进行相结合,在缓存中缓存一份虚拟DOM,当数据发生改变的时候

    会将虚拟DOM与缓存中的虚拟DOM进行比较(diff算法)。比较完毕以后,将需要修改的虚拟DOM进行批量修改。

    而不是全部修改,减少不必要的更新

    3、什么叫做diff算法

    新旧两个虚拟DOM的对比就是tree diff

    componentDidMount:

    render函数执行完毕以后componentDidMount就会去执行。在这个生命周期函数里面我们可以进行fetch的请求

    以及获取到真实的DOM结构

    componentWillUnmount:

    组件销毁

    shouldComponentUpdate:

    1、当this.state/this.props发生改变的时候会执行render函数,

    2、shouldComponentUpdate这个生命周期函数必须要返回一个布尔值 如果返回true则下面的生命周期函数继续执行,

    如果返回false下面的生命周期函数不在执行

    3、shouldComponentUpdate这个生命周期函数主要是用来判断DOM是否更新 而不是数据是否更新(不管返回值是true或者

    false,this.state中的数据肯定会发生改变,但是如果返回值是false的情况下DOM是不会进行更新的

    )

    4、shouldComponentUpdate这个生命周期函数里面我们可以做一些相关的操作来减少虚拟DOM不必要的更新(利用

    shouldComponentUpdate中接受到的2个参数 一个是新的props 一个是新的state 进行比较

    )

    componentWillUpdate:

    更新前:

    虚拟DOM与数据进行相结合,但是没有生成真正的DOM结构

    componentDidUpdate:

    更新后:

    数据和模板进行相结合生产了真正的DOM结构,在这里可以获取到数据更新后最新的DOM结构

    componentWillReceiveProps:

    当外部属性发生改变的时候就会执行当前生命周期函数,当前生命周期函数会有一个参数是新的Prop

    操作DOM的两种方式

    1、ref="list" this.refs.list

    2、ref={(tagName)=>{this.key = tagName}} this.key

    document.getElementById("list") || this.refs 区别?(作业)

    react生命周期函数中有哪些生命周期函数只会执行一次?

    constructor

    componentWillMount

    componentDidMount

    componentWillUnMount

    react生命周期函数中有哪些生命周期函数会执行多次?

    componentWillRecevieProps

    shouldComponentUpdate

    componentWillUpdate

    render

    componentDidUpdate

  • 相关阅读:
    搭建Go调试环境(LiteIDE)
    golang编译工具LiteIDE的调试使用方法(F5)
    Golang并发模型:轻松入门流水线FAN模式
    Golang并发中channel的分析
    需求设计说明书的重要性
    Chrome开发者工具详解-Elements、Console、Sources面板
    Chrome开发者工具详解(5)-Application、Security、Audits面板
    bzoj1216: [HNOI2003]操作系统
    bzoj1150: [CTSC2007]数据备份Backup
    bzoj1059: [ZJOI2007]矩阵游戏
  • 原文地址:https://www.cnblogs.com/zdhBK/p/10123431.html
Copyright © 2011-2022 走看看