学习React(四)

学习React(四)

componentWillMount(被放弃使用)

复制代码
组件被挂载(渲染)到页面之前,自动执行,此时render函数,还没有执行,无法在这一步操作真实DOM

render

复制代码
挂载(渲染)页面,把虚拟DOM转换成真实DOM,即定义的变量以及jsx被执行

componentDidMount

复制代码
组件被挂载(渲染)到页面之后,自动执行,此时render函数,已经执行完成,可以在这一步进行DOM节点的操作

shouldComponentUpdate(nextProps,nextState)

复制代码
组件被更新之前(即每次改变state,props的值都会执行该函数),自动执行,它会返回true或者false,返回true就继续执行componentWillUpdate,否则就不执行,
可以通过nextProps.[属性值]与当前this.props.[属性值]比较是否一样,来选择return true还是return false,来执行组件中的render函数

componentWillUpdate(被放弃使用)

复制代码
执行在shouldComponentUpdate之后,shouldComponentUpdate返回值为true,才执行componentWillUpdate,接着继续执行render函数重新渲染页面,当页面渲染完成后执行componentDidUpdate

componentDidUpdate

复制代码
组件更新完成之后,自动执行

componentWillReceiveProps(被放弃使用)

复制代码
该函数要执行的条件:
1.首先它要从父组件接受参数;
2.这个组件要已经在父组件中渲染过一次,才会执行,如果这个组件是第一次存在于父组件中,就不会执行

componentWillUnmount

复制代码
组件被删除之前,自动执行

react运行的生命周期

复制代码
1.Initialization(初始化):初始化页面在构造函数中获取props值,以及state值的设置,页面创建过程中只执行一次

2.Mounting(挂载):设置好props和state的值之后,开始挂载(渲染)页面,页面创建过程中只执行一次

3.Updation(更新):当页面中state,props的值开始改变时,执行这里的函数

4.Unmounting(销毁):页面卸载时,自动执行
相关推荐
老王以为1 天前
React Renderer 分离的多平台架构
前端·react native·react.js
张元清1 天前
React useDebounce Hook:给状态和回调做防抖(2026)
javascript·react.js
YFF菲菲兔2 天前
useState 源码解析
react.js
Flynt3 天前
我的Next.js项目升级到16之后,dev倒是快了,但build差点让我回退
react.js·next.js·turbopack
光影少年3 天前
HashRouter 和 BrowserRouter 区别、底层原理、部署差异
前端·react.js·nestjs
kyriewen4 天前
我用 50 行代码重写了 React Router 核心,终于搞懂了前端路由原理
前端·javascript·react.js
ZhengEnCi4 天前
Q02-Vue-React-index.html完全指南
vue.js·react.js·html
weedsfly4 天前
JavaScript 事件流:彻底搞懂捕获、冒泡与事件委托
前端·javascript·react.js
光影少年6 天前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
YAwu117 天前
深入解析 React 炫彩鼠标跟随标题组件:从坐标定位到动画性能
前端·react.js