【React】React入门--生命周期

news2025/1/20 4:50:08

🎀个人主页:努力学习前端知识的小羊
感谢你们的支持:收藏🎄 点赞🍬 加关注🪐

文章目录

    • React生命周期
      • 初始化阶段
      • 运行中阶段
      • 销毁阶段
      • 老生命周期的问题
      • 新生命周期代替
      • 性能优化的方案
      • 重要的勾子
      • 即将废弃的勾子

React生命周期

react生命周期分为三个阶段—初始化阶段运行中阶段销毁阶段

react旧生命周期流程图如下:
在这里插入图片描述

初始化阶段

  • componentWillMount: 组件将要挂载,初始化数据的作用,只调用一次 , render之前最后一次修改状态的机会(不安全)
  • render:挂载组件,只能访问this.props和this.state,不允许修改状态和DOM输出
  • componentDidMount: 组件挂载完成,成功render并渲染完成真实DOM之后触发,可以修改DOM
    可以用于数据请求axios,订阅函数调用,给予创建的dom进行初始化,开启定时器
UNSAFE_componentWillMount(){
        console.log("第一次将要挂载",this.state.name,document.getElementById('myname').innerHTML);

// 第一次上树前的最后一次修改状态机会
        this.setState({
            name:'Kerwin'
        })

        //初始化数据的作用
    }
    componentDidMount(){
        console.log('第一次已经挂载',document.getElementById('myname').innerHTML);
        // 数据请求axios
        // 订阅函数调用
        // setInternal
        //基于创建的dom进行 初始化...BetterScoll
    }

运行中阶段

  • componentWillUpdate: 更新前的数据状态(不安全),不能修改属性和状态
  • componentDidUpdate:可以修改Dom,每次更新都会执行一次 含有两个属性:prevProps:旧的属性,prevState:旧的状态
  • render:组件更新 shouldComponentUpdate: 决定是否进行更新return true:应该更新,return false:阻止更新 含有两个参数:nextProps:新属性,nextState:新状态
  • componentWillReceiveProps: 最先获得父组件传来的属性,父组件一修改便会触发(非首次)

componentWillUpdatecomponentDidUpdate使用

//   不安全
  UNSAFE_componentWillUpdate(){
    console.log("componentWillUpdate",document.getElementById('myname').innerHTML);
  }

// 每次更新都会执行一次
  componentDidUpdate(prevProps,prevState){   //prevProps:老的属性
    console.log("componentDidUpdate",document.getElementById('myname').innerHTML);

    // 更新后,想要获取dom节点,更新
    new BScroll('#wrapper')
    console.log(prevProps,prevState);

    //进行判断,只调用一次
    if(prevState.list.length === 0){
        new BScroll("#wrapper")
    }
  }

shouldComponentUpdate的使用:

shouldComponentUpdate(nextProps,nextState){
    // return true; //应该更新
    // return false;  //组织更新
    // 老状态:this.state;新状态:nextState;新属性:nextProps

    // 通过状态的字符串是否一样来判断
    if(JSON.stringify(this.state) !== JSON.stringify(nextState)){
        return true;
    } else{
        return false;
    }
  }
	

componentWillReceiveProps的使用:

UNSAFE_componentWillReceiveProps(nextProps){
        console.log("componentWillReceiveProps",
        this.props.text,nextProps);

        // 最先获得父组件传来的属性,可以利用属性进行Ajax或逻辑处理
        // 将属性转化为孩子自己的状态
        this.setState({
            title:nextProps.text
        })
    }

销毁阶段

componentWillUnmount: 再删除组件之前进行清理作用,如清除挂载的定时器和事件监听器

componentDidMount(){
        window.onresize=()=>{
            console.log("resize");
        }

        this.timer = setInterval(()=>{
            console.log(1);
        },1000)
    }
//进行销毁
    componentWillUnmount(){
        console.log("componentWillUNMount");
        //取消监听事件
        window.onresize=null
		//清除定时器
        clearInterval(this.timer)
    }

老生命周期的问题

  • componentWillMount 在ssr(服务器渲染)中这个方法将会被多次调用,所以会重复触发多遍,同时在这里如果绑定事件,将无法解绑,导致内存泄漏,变得不够安全高效逐步废弃。
  • componentWillReceiveProps外部组件多次频繁更新传入多次不同的props,会导致不必要的异步请求
  • componetwilupdate,更新前记录DOM状态,可能会做一些处理,与componentDidUpdate相隔时间如果过长,会导致状态不太信

新生命周期代替

新生命周期流程图:
在这里插入图片描述

static getDerivedStateFromProps :从props得到一个派生状态,第一次的初始化组件以及后续的更新过程中(包括自身状态更新以及父传子),返回一个对象作为新的state,返回null则说明不需要在这里更新state

// 适用于初始化和后续更新
    static getDerivedStateFromProps(nextProps,nextState){
        console.log('getDerivedStateFromProps',nextState);
        return {
            myname:nextState.myname
        }
    }

getSnapshotBeforeUpdate:在组件更新之前获取快照,即记录更新前的数据和状态,返回的值作为componentDidUpdate的第三个参数

componentDidUpdate = (prevProps, prevState,value) => {
  console.log("componentDidUpdate",value);  //value:100
}

getSnapshotBeforeUpdate(){
    console.log('getSnapshotBeforeUpdate');
    return 100
}

性能优化的方案

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 也需要花时间。

重要的勾子

  • render:初始化渲染或更新渲染调用

  • componentDidMount:开启监听,发送axios请求

  • componentWillUnmount:做一些收尾工作,如清理定时器和事件监听器

即将废弃的勾子

  • componentWillMount

  • componentWillReceiveProps

  • componentWillUpdate

注:使用时会出现警告,需要加上UNSAFE_前缀才能使用,以后可能被弃用

希望能够对学习react的小伙伴们有所帮助,期待你们的支持哦✨✨✨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408813.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ElementUI样式优化1】el-table 修改斑马格样式、修改滚动条样式、添加表头边框、删除表格边框划线

重要的不是过去,而是你怎末看待过去,而我们对过去的看法,是可以改变的。 效果预览: (1)删除表格外框,内框。 (2)添加表头边框,修改表头文字大小、颜色 &…

猿创征文 |【高级篇】Java 进阶之JVM实战

文章目录⚡前言一、面试题解析二、JVM 理论详解⛅JVM的位置❄️JVM的体系结构⏳类加载器三、JVM 双亲委派机制四、Native 关键字五、PC寄存器 与 方法区六、栈与堆七、三种JVM、新生区、老年区、永久区⛵小结⚡前言 JVM 是 Java 实现 跨平台的基础,所有的Java 程序…

[遇到的问题-已解决]Cannot resolve plugin org.apache.maven.plugins:maven-compiler-plugin:3.1

如上图所示,这是我解决好的,刚开始的时候爆红有这些: 我按照在网上查找的方法,一一试了。 首先,maven 安装的路径和和本地仓库的目录必须要保持一致 打开setting-Build,Excution,Deployment-Build Tools-Maven&#…

vue框架介绍

概述 Vue 是一套用于构建用户界面的渐进式框架 对渐进式的理解: 每个框架都不可避免会有自己的一些特点,从而会对使用者有一定的要求,这些要求有强有弱,它的强势程度会影响在业务开发中的使用方式。 vue的定位: 我在做…

【Vue入门必备知识篇03】--- 生命周期 数据共享

前言❤️ 过好自律的生活,美好才会在路上不期而遇 ❤️【Vue入门必备知识篇03】--- 生命周期 & 数据共享一、生命周期 & 数据共享(1)组件的生命周期1.1 生命周期 & 生命周期函数1.2 组件生命周期函数的分类1.3 生命周期图示&…

记录Chrome插件从V2版本升级到V3版本的过程中遇到的问题

总结一下自己在把Chrome V2版本的插件升级到V3版本的过程中,遇到的一些问题,之前也有发布一章V3版本的manifest.json配置项参数说明,基本也涵盖了下面提到的几个配置项的改动,传送门>> 总结分了两大块,一块是ma…

【Node.js】深度解析常用核心模块-fs模块

✅ 作者简介:一名将要迈入大三的大学生,致力于提高前端开发能力 ✨ 个人主页:前端小白在前进的主页 🔥 系列专栏 : node.js学习专栏 ⭐️ 个人社区 : 个人交流社区 🔥前言 在文章👉Node.js — 前…

React脚手架工具创建项目的详细介绍

文章目录React脚手架工具脚手架工具解析create-react-app创建React项目目录的结构分析从零编写代码React脚手架工具 脚手架工具解析 如果我们只是开发几个小的demo程序,那么永远不需要考虑一些复杂的问题: 比如目录结构如何组织划分; 比如如何管理文件之间的相互依…

Python lxml库的安装和使用

lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 Xpath 表达式提供了良好的支持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 安装lxml库 lxml 属于 Python 第三方库,因此需要…

全网多种方式解决Unchecked runtime.lastError: The message port closed before a response was received的错误

文章目录1. 文章引言2. 分析问题3. 解决问题4. 解决该错误的其他方法1. 文章引言 今天启动项目后访问Knife4j接口文档,却报出下图错误: 在报出Knife4j文档请求异常错误时,赶紧打开控制台,如下所示: 即Unchecked runti…

CSS过渡动画

css中实现动画有两种方式:transition过渡动画、 animation自定义动画。 transition 是 css3 新增的⼀个功能,可以实现元素不同状态间的平滑过渡(当元素从⼀个状态进⼊到另⼀个状态时),经常⽤来制作⼀些动画效果。 之…

前端项目面试核心问题(持续更新)

本文有配套视频教程 项目面核心问题回答思路 说说你最近的项目 记叙文的六要素:时间、人物、地点、起因、经过、结果;时间:研发周期;人物:团队成员、分工、我负责哪几个模块;起因:项目背景、…

Vue项目实战——【基于 Vue3.x + Vant UI】实现一个多功能记账本(开发导航栏及公共部分)

基于 Vue3.x Vant UI 的多功能记账本(三) 文章目录基于 Vue3.x Vant UI 的多功能记账本(三)项目演示开发导航栏1、底部导航栏2、测试底部导航栏3、公共头部写到最后(附源码)系列内容参考链接基于 Vue3.x …

element-UI组件之日期时间选择器与时间格式转化

element-UI组件之日期时间选择器与时间格式转化日期选择器与时间选择器的一般使用日期时间选择器选择日期时间点选择日期范围日期选择器月份范围选择器禁选日期用time.getTime()进行日期(时间)格式的转换时间选择器el-time-select选择固定时间点el-time-picker选择任意时间点禁…

Vite 基本配置及原理

Vite 基本配置及原理介绍vite.config.jsoptimizeDeps.exclude不同环境的 vite 配置css配置Vite 对 css 的处理Vite 对 cssmodule 的处理和配置Vite 对预处理器的配置devSourcemapVite 对 postcss 的支持Vite 静态资源别名设置Vite 生产环境配置介绍 如果你还不知道 Vite&#…

【Vue入门必备知识篇05】--- Vue Router路由

前言❤️ 当落日余晖照在身上,没有污秽没有杂尘,只有光和希望 ❤️【Vue入门必备知识篇05】--- Vue Router路由一、前端路由的概念与原理(1)什么是路由(2)SPA 与前端路由(3)什么是前…

vue-router中的参数传递

文章目录前言一、本文章中练习需要的准备工作暴力引入bootstrap安装Vue Router二、项目基本架构1. 配置router文件2. 写入路由组件 一级路由3. 二级路由 实现传参3.1 使用params 传参3.1.1 在router文件下配置二级路由3.1.2 在view文件下新建二级路由组件3.1.3 在上一级路由组件…

uniapp**字符串转Json并提取字段值

uniapp字符串转Json并提取字段值 JSON有三种格式,每一种写法都和JS中的数据类型很像,可以很轻松的和JS中的数据类型互相转换 一、简单值的形式:JSON的简单值的格式对应着JS中的基础数据类型:数字 字符串 布尔值 注意事项&#…

这是我见过最牛逼的滑动加载前端框架

文章目录前言一、mescroll简介二、快速开始三、一分钟入门mescroll图片懒加载四、mescroll在vue中的使用五、小结前言 在手机端实现下拉刷新和下拉加载是最常见不过的需求了。今天大师兄就给大家分享一个非常精致的js框架:mescroll. 提示:以下是本篇文…

Cursor:GPT-4 驱动的强大代码编辑器

Cursor (https://www.cursor.so/)是 GPT-4 驱动的一款强大代码编辑器,可以辅助程序员进行日常的编码。下面通过一个实际的例子来展示 Cursor 如何帮助你编程。这个例子做的事情是网页抓取。抓取的目标是百度首页上的百度热搜,如下…