欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React的生命周期詳解

 更新時(shí)間:2022年06月28日 09:34:54   作者:小旭2021  
React是用于構(gòu)建用戶界面的JavaScript庫(kù)。本文詳細(xì)講解了React的生命周期,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、React生命周期

React 生命周期分為三種狀態(tài)

  • 1. 初始化
  • 2.更新
  • 3.銷毀

初始化

1、getDefaultProps()

設(shè)置默認(rèn)的props,也可以用dufaultProps設(shè)置組件的默認(rèn)屬性.

2、getInitialState()

在使用es6的class語(yǔ)法時(shí)是沒有這個(gè)鉤子函數(shù)的,可以直接在constructor中定義this.state。此時(shí)可以訪問this.props

3、componentWillMount()

組件初始化時(shí)只調(diào)用,以后組件更新不調(diào)用,整個(gè)生命周期只調(diào)用一次,此時(shí)可以修改state。

在渲染前調(diào)用,在客戶端也在服務(wù)端。

4、 render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行。此時(shí)就不能更改state了。

5、componentDidMount()

組件渲染之后調(diào)用,只調(diào)用一次。

在第一次渲染后調(diào)用,只在客戶端。之后組件已經(jīng)生成了對(duì)應(yīng)的DOM結(jié)構(gòu),可以通過this.getDOMNode()來進(jìn)行訪問。

如果你想和其他JavaScript框架一起使用,可以在這個(gè)方法中調(diào)用setTimeout, setInterval或者發(fā)送AJAX請(qǐng)求等操作(防止異步操作阻塞UI)。

更新

6、componentWillReceiveProps(nextProps)

組件初始化時(shí)不調(diào)用,組件接受新的props時(shí)調(diào)用。

使用componentWillReceiveProps的時(shí)候,不要去向上分發(fā),調(diào)用父組件的相關(guān)setState方法,否則會(huì)成為死循環(huán)

在組件接收到一個(gè)新的 prop (更新后)時(shí)被調(diào)用。這個(gè)方法在初始化render時(shí)不會(huì)被調(diào)用。

7、shouldComponentUpdate(nextProps, nextState)

react性能優(yōu)化非常重要的一環(huán)。組件接受新的state或者props時(shí)調(diào)用,我們可以設(shè)置在此對(duì)比前后兩個(gè)props和state是否相同,

如果相同則返回false阻止更新,因?yàn)橄嗤膶傩誀顟B(tài)一定會(huì)生成相同的dom樹,這樣就不需要?jiǎng)?chuàng)造新的dom樹和舊的dom樹進(jìn)行diff算法對(duì)比,

節(jié)省大量性能,尤其是在dom結(jié)構(gòu)復(fù)雜的時(shí)候

返回一個(gè)布爾值。在組件接收到新的props或者state時(shí)被調(diào)用。

在初始化時(shí)或者使用forceUpdate時(shí)不被調(diào)用。

可以在你確認(rèn)不需要更新組件時(shí)使用。

8、componentWillUpdata(nextProps, nextState)

組件初始化時(shí)不調(diào)用,只有在組件將要更新時(shí)才調(diào)用,此時(shí)可以修改state

9、render()

組件渲染

10、componentDidUpdate()

組件初始化時(shí)不調(diào)用,組件更新完成后調(diào)用,此時(shí)可以獲取dom節(jié)點(diǎn)。

卸載

11、componentWillUnmount()

組件將要卸載時(shí)調(diào)用,一些事件監(jiān)聽和定時(shí)器需要在此時(shí)清除。

二、組件生命周期的執(zhí)行次數(shù)是什么樣子的

只執(zhí)行一次: constructor、componentWillMount、componentDidMount

執(zhí)行多次:render 、子組件的componentWillReceiveProps、componentWillUpdate、componentDidUpdate

有條件的執(zhí)行:componentWillUnmount(頁(yè)面離開,組件銷毀時(shí))

不執(zhí)行的:根組件(ReactDOM.render在DOM上的組件)的componentWillReceiveProps(因?yàn)閴焊鶝]有父組件給傳遞props)

三、React生命周期執(zhí)行順序

Mounting中為組件的掛載過程

  • componentWillMount組件掛載之前
  • render組件的渲染方法
  • componentDidMount組件掛載完成執(zhí)行

Updation中為組件數(shù)據(jù)發(fā)生變化的過程

props獨(dú)有

componentWillReceiveProps 

觸發(fā)條件

  • 1. 當(dāng)一個(gè)組件從父組件接收了參數(shù)。
  • 2.如果這個(gè)組件第一次被父組件加載的時(shí)候不會(huì)被執(zhí)行。
  • 3.這個(gè)組件之前已經(jīng)存在于父組件中,并且接收的數(shù)據(jù)發(fā)生變動(dòng)這時(shí)此方法才會(huì)被觸發(fā)。  

props和states共有

  • shouldComponentUpdata:是否要更新數(shù)據(jù)?需要一個(gè)返回值true繼續(xù)執(zhí)行下面的生命周期,false就會(huì)終止當(dāng)前組件數(shù)  
  • componentWillUpdate:組件將要更新
  • render:組件的重新渲染
  • componentDidUpdata:組件完成更新

Unmounting組件卸載

componentWillUnmount:組件銷毀的時(shí)候觸發(fā)

到此這篇關(guān)于React生命周期的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • react項(xiàng)目打包后點(diǎn)擊index.html頁(yè)面出現(xiàn)空白的問題

    react項(xiàng)目打包后點(diǎn)擊index.html頁(yè)面出現(xiàn)空白的問題

    這篇文章主要介紹了react項(xiàng)目打包后點(diǎn)擊index.html頁(yè)面出現(xiàn)空白的問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • React Electron生成桌面應(yīng)用過程

    React Electron生成桌面應(yīng)用過程

    這篇文章主要介紹了React+Electron快速創(chuàng)建并打包成桌面應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • react將文件轉(zhuǎn)為base64上傳的示例代碼

    react將文件轉(zhuǎn)為base64上傳的示例代碼

    本文主要介紹了react將文件轉(zhuǎn)為base64上傳的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-09-09
  • 利用CDN加速react webpack打包后的文件詳解

    利用CDN加速react webpack打包后的文件詳解

    下面小編就為大家分享一篇利用CDN加速react webpack打包后的文件詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • react如何用懶加載減少首屏加載時(shí)間

    react如何用懶加載減少首屏加載時(shí)間

    這篇文章主要介紹了react如何利用懶加載減少首屏加載時(shí)間,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下
    2021-04-04
  • React18中請(qǐng)求數(shù)據(jù)的官方姿勢(shì)適用其他框架

    React18中請(qǐng)求數(shù)據(jù)的官方姿勢(shì)適用其他框架

    這篇文章主要為大家介紹了官方回答在React18中請(qǐng)求數(shù)據(jù)的正確姿勢(shì)詳解,同樣也適用其他框架,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • D3.js(v3)+react 實(shí)現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本)

    D3.js(v3)+react 實(shí)現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本)

    散點(diǎn)圖(Scatter Chart),通常是一橫一豎兩個(gè)坐標(biāo)軸,數(shù)據(jù)是一組二維坐標(biāo),分別對(duì)應(yīng)兩個(gè)坐標(biāo)軸,與坐標(biāo)軸對(duì)應(yīng)的地方打上點(diǎn)。由此可以猜到,需要的元素包括circle(圓)和axis(坐標(biāo)軸),接下來通過本文大家分享D3.js(v3)+react 實(shí)現(xiàn)帶坐標(biāo)與比例尺的散點(diǎn)圖 (V3版本) ,一起看看
    2019-05-05
  • React如何利用Antd的Form組件實(shí)現(xiàn)表單功能詳解

    React如何利用Antd的Form組件實(shí)現(xiàn)表單功能詳解

    這篇文章主要給大家介紹了關(guān)于React如何利用Antd的Form組件實(shí)現(xiàn)表單功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 關(guān)于react中useCallback的用法

    關(guān)于react中useCallback的用法

    這篇文章主要介紹了關(guān)于react中useCallback的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • React+Mobx基本使用、模塊化操作

    React+Mobx基本使用、模塊化操作

    React 和 MobX 是一對(duì)強(qiáng)力組合,React 通過提供機(jī)制把應(yīng)用狀態(tài)轉(zhuǎn)換為可渲染組件樹并對(duì)其進(jìn)行渲染,而MobX提供機(jī)制來存儲(chǔ)和更新應(yīng)用狀態(tài)供 React 使用,這篇文章主要介紹了React+Mobx基本使用、模塊化,需要的朋友可以參考下
    2022-09-09

最新評(píng)論