React生命周期函數(shù)圖解介紹
生命周期的三個(gè)階段
1.創(chuàng)建時(shí)(掛載階段)
①執(zhí)行時(shí)機(jī):組件創(chuàng)建時(shí)(頁(yè)面加載時(shí))
②執(zhí)行順序:constructor()->render()->componentDidMount()
import React, { Component } from 'react' export default class extends Component { constructor(){ super() console.log("constructor");//第一個(gè)打印 } componentDidMount(){ console.log("componentDidMount");//第三個(gè) } render() { console.log("render");//第二個(gè) return ( <div></div> ) } }
2.更新時(shí)(更新階段)
①執(zhí)行時(shí)機(jī):1.setState()2.forceUpdate()3.組件接收到新的props,這三者任意一種變化,組件就會(huì)重新渲染
3.卸載時(shí)(卸載階段)
①執(zhí)行時(shí)機(jī):組件從頁(yè)面中消失
不常用生命周期函數(shù)
1.static getDerivedStatesFromProps( nextProps, pervState) 靜態(tài)方法生命周期函數(shù)
①執(zhí)行時(shí)機(jī):會(huì)在調(diào)用render方法之前調(diào)用,并且在初始掛載、更新時(shí)都會(huì)被調(diào)用。它應(yīng)返回一個(gè)對(duì)象來(lái)更新state,如果返回的是null則不更新任何內(nèi)容。
②使用靜態(tài)方法,可以強(qiáng)制開(kāi)發(fā)者在render之前只做無(wú)副作用的操作,而且能做的操作局限在props和state決定新的state而已。
2.shouldCompontentUpdate(nextProps, nextState) 是否要更新組件時(shí)觸發(fā)的函數(shù)
①判斷是否需要更新,主要用來(lái)優(yōu)化性能,調(diào)用this.forceUpdate會(huì)無(wú)視這個(gè)鉤子,強(qiáng)制更新。
可以通過(guò)比較this.props和nextProps、this.state和nextState來(lái)判斷狀態(tài)是否發(fā)生改變;狀態(tài)發(fā)生變化,組件會(huì)進(jìn)入渲染流程,renturn false可以阻止組件更新
②父組件的重新渲染會(huì)導(dǎo)致組件重新渲染??梢酝ㄟ^(guò)此鉤子函數(shù)限制子組件是否需要更新。
3.getSnapshotBeforeUpdate(prevProps, prevState) 保存狀態(tài)快照
①主要用來(lái)代替componentWillUpdate生命周期函數(shù)。
②執(zhí)行時(shí)機(jī):會(huì)在最終的render之前被調(diào)用,它與componentDidUpdate函數(shù)中的元素狀態(tài)是一致的
到此這篇關(guān)于React生命周期函數(shù)圖解介紹的文章就介紹到這了,更多相關(guān)React生命周期函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入理解React Native原生模塊與JS模塊通信的幾種方式
本篇文章主要介紹了深入理解React Native原生模塊與JS模塊通信的幾種方式,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07在React項(xiàng)目中使用iframe嵌入一個(gè)網(wǎng)站的步驟
本文介紹了如何在React項(xiàng)目中通過(guò)iframe嵌入百度網(wǎng)站的步驟,首先創(chuàng)建一個(gè)Baidu.js組件,并在該組件中設(shè)置iframe來(lái)加載百度,然后在App.js中引入并使用Baidu組件,還討論了因安全策略可能無(wú)法加載某些網(wǎng)站的問(wèn)題,需要的朋友可以參考下2024-09-09React實(shí)現(xiàn)antdM的級(jí)聯(lián)菜單實(shí)例
這篇文章主要為大家介紹了React實(shí)現(xiàn)antdM的級(jí)聯(lián)菜單實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10React工作流程及Error Boundaries實(shí)現(xiàn)過(guò)程講解
這篇文章主要介紹了React工作流程及Error Boundaries實(shí)現(xiàn)過(guò)程講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-02-02React如何通過(guò)@craco/craco代理接口
這篇文章主要介紹了React如何通過(guò)@craco/craco代理接口問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10React如何使用refresh_token實(shí)現(xiàn)無(wú)感刷新頁(yè)面
本文主要介紹了React如何使用refresh_token實(shí)現(xiàn)無(wú)感刷新頁(yè)面,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04