React(三) ——新、旧生命周期

简介: React(三) ——新、旧生命周期

⛳React生命周期


🌋初始化阶段

由 ReactDOM.render()触发 —— 初次渲染

componentWillMount()

⚡1. 组件将要被挂载,第一次上树前render之前最后一次修改状态的机会

⚡2. 初始化数据的作用

⚡3. 清除计时器,取消订阅

注意:出现黄色警告,可以写成

UNSAFE_componentWillMount(){}
//因为其旧版本componentWillMount优先级较低,可以会被打断,会再次执行,不够安全

render()

🚀1. 正在渲染

🚀2. 只能访问this.props和this.state,不允许修改状态和Dom输出

componentDidMount()

📢1. 组件挂载完毕,成功render并渲染完成真实Dom之后触发,可以修改Dom

📢2. 常用于: 数据请求、订阅函数调用、设置计时器、基于创建完的dom进行初始化 BetterSroll

📢3.语法:componentDidMount()

👣运行中阶段

由组件内部 this.setState() 或 父组件重新render触发

componentWillReceiveProps()

📌1. 父组件修改属性触发,最先获得父组件传来的属性,可以利用属性进行ajax或者逻辑处理

📌2. 只能在子组件中使用

📌3. 可以将属性转化成孩子自己的状态

state={
    title:'zhangsan'
}  
.......................
componentWillReceiveProps(nextProps){
      //this.props.text 老的属性
      //nextProps 新的属性
      this.setState({
          title:nextProps.text//可以将属性转化成孩子自己的状态
      })
    }

shouldComponentUpdate()

📢1. 是否要进行修改数据

📢2. shouComponentUpdate(nextProps,nextState)两个参数,第一个为新的属性,第二个为新的状态

📢3. 返回true或false来控制组件是否更新

shouldComponentUpdate(nextProps,nextState){
    //this.state 老的状态,nextState 新的状态
    /*if( 老的状态!== 新的状态){
        return true;
    }*/
    //如果state中既有对象又有数组需要比较较麻烦时,可以将其转为字符串在进行比较
    if(JSON.stringify(this.state))!== JSON.stringify(nextState){
        return true
    }
    return false;
  }

注意:给返回true时加上适合的条件,会提高性能

componentWillUpdate()

  1. 将要改变数据
UNSAFE_componentWillUpdate(){}

componentDidUpdate()

首次渲染不会执行该方法,会在更新后被立即调用

💧1. 改变数据

💧2. 更新多次

💧3. 修改dom节点等一系列操作

componentDidUpdate(prevProps,prevState){
    //可以通过参数获得老的属性和状态
    console.log(prevProps,prevState.list);
    //更新后,获取dom节点,进行一系列操作
    if(prevState.list.length == 0){
        new BetterScroll("#warpper")
    } console.log('componentDidUpdate',document.getElementById('myname').innerHTML);
  }

注意:这个时候已经二次render完了,不存在nextProps,this.props中已经是最新的数据了,所以想得到最新的属性值,直接通过this.props拿

🏓销毁阶段

componentWillUnmount()

💦在删除组件之前进行清理操作,比如计时器和事件监听器

🏫新生命周期的替代


getDerivedStateFromProps

🎀1. 静态方法,第一次的初始化组件以及后续的更新过程中(包括自身状态以及父传子),返回一个对象作为新的state,返回null则说明不需要在这里更新state

🎀2. 适用于 第一次 和 后续更新 都 重复的逻辑

  state={
      myname:'zhangsan'
  }
  //componentWillMount 初始化
  static getDerivedStateFromProps(nextProps,nextState){
    return{
        //此处此myname将覆盖其他地方的myname
        myname:nextState.myname
    }
  }
  render() {
    return (
      <div>
        <button onClick={()=>{
            this.setState({
                myname:'lisi'
            })
        }}>click</button>
        {this.state.myname}
      </div>
    )
  }
}

注意:此方法中的属性 会覆盖 其他地方相同的属性(即使再次进行render执行或this.setState修改)

getSnapshotBeforeUpdate

取代了componentWillUpdate,触发时间为update发生的时候,在render之后dom渲染之前 返回一个值,作为componentDidUpdate的第三个参数

getSnapshotBeforeUpdate(prevProps,prevState){
    //组件能在发生更新之前从 DOM 中捕获一些信息(例如,滚动位置)
    return "aaa"//snapshotValue
}
..............................
componentDidUpdate(preProps,preState,snapshotValue){
    console.log(snapshotValue)
    //"aaa"
}

🚚react中性能优化方案

shouldComponentUpdate

控制组件自身或者子组件是否需要更新,尤其在子组件非常多的情况下,需要进行优化

PureComponent


PureComponent会帮你比较新props跟旧的props,新的state和老的state(值相等,或者对象含有相同的属性、且属性值相等),决定shouldcomponentUpdate 返回true或者false,从而决定要不要呼叫render function

import React, { PureComponent } from 'react'
export default class App extends PureComponent {}

注意:如果 state或props 永远都会变(比如倒计时),但PureComponent并不会比较快,因为shallowEqual也需要花时间

🎉🎉🎉如有错误,请评论指出,thankyou~🎀🎀🎀

✨✨✨创作不易,如对您有帮助,欢迎给博主点赞收藏,给予鼓励哟💛

相关文章
|
4月前
|
前端开发
react生命周期的一些坑
react生命周期的一些坑
|
4月前
|
前端开发 JavaScript 开发者
【第27期】一文了解React生命周期
【第27期】一文了解React生命周期
35 0
|
4月前
|
前端开发
React中生命周期的讲解
React中生命周期的讲解
|
5月前
|
前端开发 JavaScript
react 生命周期讲解
react 生命周期讲解
|
1月前
|
前端开发 JavaScript
React生命周期方法在实际开发中的应用场景有哪些?
【4月更文挑战第6天】 React 生命周期方法应用于数据获取、订阅管理、渲染逻辑处理、用户交互响应、性能优化、资源清理、强制更新、错误处理、动画实现、代码分割、服务端渲染、路由处理、依赖注入和集成第三方库。它们帮助控制组件行为和性能,但现代开发推荐使用Hooks替代部分生命周期方法。
16 0
|
1月前
|
前端开发 JavaScript
react生命周期函数
react生命周期函数
|
4月前
|
前端开发
React旧有生命周期和新生命周期的解析
React旧有生命周期和新生命周期的解析
30 0
React旧有生命周期和新生命周期的解析
|
4月前
|
前端开发 JavaScript API
React组件生命周期
React组件生命周期
76 1
|
4月前
|
前端开发 JavaScript 测试技术
第十三章 React生命周期(新)
第十三章 React生命周期(新)
|
4月前
|
前端开发 JavaScript
第十二章 引出React中的生命周期
第十二章 引出React中的生命周期