組件的生命周期是什么?-創(chuàng)新互聯(lián)

1、生命周期的概念

1.1、概念

在組件創(chuàng)建、組件屬性更新、組件被銷毀的過程中,總是伴隨著各種各樣的函數(shù)執(zhí)行,這些在組件特定時期,被觸發(fā)執(zhí)行的函數(shù),統(tǒng)稱為組件的生命周期函數(shù)。

10多年專注成都網(wǎng)站制作,企業(yè)網(wǎng)站設(shè)計,個人網(wǎng)站制作服務(wù),為大家分享網(wǎng)站制作知識、方案,網(wǎng)站設(shè)計流程、步驟,成功服務(wù)上千家企業(yè)。為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及定制高端網(wǎng)站建設(shè)服務(wù),專注于企業(yè)網(wǎng)站設(shè)計,高端網(wǎng)頁制作,對咖啡廳設(shè)計等多個領(lǐng)域,擁有豐富的網(wǎng)站建設(shè)經(jīng)驗。

1.2、組件生命周期三個階段

  1. 加載階段(Mounting):在組件初始化時執(zhí)行,有一個顯著的特點:創(chuàng)建階段生命周期函數(shù)在組件的一輩子中只執(zhí)行一次;

  2. 更新階段(Updating):屬性和狀態(tài)改變時執(zhí)行,根據(jù)組件的state和props的改變,有選擇性的觸發(fā)0次或多次;

  3. 卸載階段(Unmounting):在組件對象銷毀時執(zhí)行,一輩子只執(zhí)行一次;

2、舊的生命周期

組件的生命周期是什么?

2.1、Mounting(加載階段:涉及6個鉤子函數(shù))

constructor()

加載的時候調(diào)用一次,可以初始化state

getDefaultProps()

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

getInitialState()

初始化state,可以直接在constructor中定義this.state

componentWillMount()

組件加載時只調(diào)用,以后組件更新不調(diào)用,整個生命周期只調(diào)用一次,此時可以修改state

render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行

componentDidMount()

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

2.2、Updating(更新階段:涉及5個鉤子函數(shù))

componentWillReceivePorps(nextProps)

組件加載時不調(diào)用,組件接受新的props時調(diào)用

shouldComponentUpdate(nextProps, nextState)

組件接收到新的props或者state時調(diào)用,return true就會更新dom(使用diff算法更新),return false能阻止更新(不調(diào)用render)

componentWillUpdata(nextProps, nextState)

組件加載時不調(diào)用,只有在組件將要更新時才調(diào)用,此時可以修改state

render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行

componentDidUpdate()

組件加載時不調(diào)用,組件更新完成后調(diào)用

2.3、Unmounting(卸載階段:涉及1個鉤子函數(shù))

componentWillUnmount()

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

2.4、生命周期函數(shù)代碼示例

import React, { Component } from 'react'

export default class OldReactComponent extends Component {
   constructor(props) {
     super(props)
     // getDefaultProps:接收初始props
     // getInitialState:初始化state
   }
   state = {

   }
   componentWillMount() { // 組件掛載前觸發(fā)

   }
   render() {
     return (
       <h3>Old React.Component</h3>
     )
   }
   componentDidMount() { // 組件掛載后觸發(fā)

   }
   componentWillReceivePorps(nextProps) { // 接收到新的props時觸發(fā)

   }
   shouldComponentUpdate(nextProps, nextState) { // 組件Props或者state改變時觸發(fā),true:更新,false:不更新
     return true
   }
   componentWillUpdate(nextProps, nextState) { // 組件更新前觸發(fā)

   }
   componentDidUpdate() { // 組件更新后觸發(fā)

   }
   componentWillUnmount() { // 組件卸載時觸發(fā)

   }
}

3、新的生命周期

3.1、Mounting(加載階段:涉及4個鉤子函數(shù))

constructor()

加載的時候調(diào)用一次,可以初始化state

static getDerivedStateFromProps(props, state)

組件每次被rerender的時候,包括在組件構(gòu)建之后(虛擬dom之后,實際dom掛載之前),每次獲取新的props或state之后;每次接收新的props之后都會返回一個對象作為新的state,返回null則說明不需要更新state;配合componentDidUpdate,可以覆蓋componentWillReceiveProps的所有用法

render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行

componentDidMount()

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

3.2、Updating(更新階段:涉及5個鉤子函數(shù))

static getDerivedStateFromProps(props, state)

組件每次被rerender的時候,包括在組件構(gòu)建之后(虛擬dom之后,實際dom掛載之前),每次獲取新的props或state之后;每次接收新的props之后都會返回一個對象作為新的state,返回null則說明不需要更新state;配合componentDidUpdate,可以覆蓋componentWillReceiveProps的所有用法

shouldComponentUpdate(nextProps, nextState)

組件接收到新的props或者state時調(diào)用,return true就會更新dom(使用diff算法更新),return false能阻止更新(不調(diào)用render)

render()

react最重要的步驟,創(chuàng)建虛擬dom,進(jìn)行diff算法,更新dom樹都在此進(jìn)行

getSnapshotBeforeUpdate(prevProps, prevState)

觸發(fā)時間: update發(fā)生的時候,在render之后,在組件dom渲染之前;返回一個值,作為componentDidUpdate的第三個參數(shù);配合componentDidUpdate, 可以覆蓋componentWillUpdate的所有用法

componentDidUpdate()

組件加載時不調(diào)用,組件更新完成后調(diào)用

3.3、Unmounting(卸載階段:涉及1個鉤子函數(shù))

componentWillUnmount()

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

3.4、Error Handling(錯誤處理)

componentDidCatch(error,info)

任何一處的javascript報錯會觸發(fā)

3.5、新生命周期函數(shù)代碼示例

import React, { Component } from 'react'

export default class NewReactComponent extends Component {
   constructor(props) {
     super(props)
     // getDefaultProps:接收初始props
     // getInitialState:初始化state
   }
   state = {

   }
   static getDerivedStateFromProps(props, state) { // 組件每次被rerender的時候,包括在組件構(gòu)建之后(虛擬dom之后,實際dom掛載之前),每次獲取新的props或state之后;;每次接收新的props之后都會返回一個對象作為新的state,返回null則說明不需要更新state
     return state
   }
   componentDidCatch(error, info) { // 獲取到j(luò)avascript錯誤

   }
   render() {
     return (
       <h3>New React.Component</h3>
     )
   }
   componentDidMount() { // 掛載后

   }  
   shouldComponentUpdate(nextProps, nextState) { // 組件Props或者state改變時觸發(fā),true:更新,false:不更新
     return true
   }
   getSnapshotBeforeUpdate(prevProps, prevState) { // 組件更新前觸發(fā)

   }
   componentDidUpdate() { // 組件更新后觸發(fā)

   }
   componentWillUnmount() { // 組件卸載時觸發(fā)

   }
}

4、總結(jié)

舊的生命周期

組件的生命周期是什么?

新的生命周期

組件的生命周期是什么?

  1. React16新的生命周期棄用了componentWillMount、componentWillReceivePorps,componentWillUpdate
  2. 新增了getDerivedStateFromProps、getSnapshotBeforeUpdate來代替棄用的三個鉤子函數(shù)(componentWillMount、componentWillReceivePorps,componentWillUpdate)
  3. React16并沒有刪除這三個鉤子函數(shù),但是不能和新增的鉤子函數(shù)(getDerivedStateFromProps、getSnapshotBeforeUpdate)混用,React17將會刪除componentWillMount、componentWillReceivePorps,componentWillUpdate
  4. 新增了對錯誤的處理(componentDidCatch)

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前名稱:組件的生命周期是什么?-創(chuàng)新互聯(lián)
文章URL:http://muchs.cn/article14/ejsde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、網(wǎng)站收錄微信公眾號、軟件開發(fā)電子商務(wù)、企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)