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

淺談react新舊生命周期鉤子

 更新時間:2023年12月06日 11:27:46   作者:佛系努力中……  
所謂的生命周期就是指某個事物從開始到結(jié)束的各個階段,本文主要介紹了淺談react新舊生命周期鉤子,具有一定的參考價值,感興趣的可以了解一下

舊生命鉤子

在這里插入圖片描述

輔助理解:

  • 紅色框:掛載時生命鉤子
  • 藍(lán)色框:更新時生命鉤子
  • 綠色框:卸載時生命鉤子

掛載時

如圖所示,我們可以看到,在組件第一次掛載時會經(jīng)歷:構(gòu)造器(constructor)=》組件將要掛載(componentWillMount)=》組件掛載渲染(render)=》組件掛載完成(componentDidMount)。

更新時

有三條路徑可以被觸發(fā),分別是紅色、橙色和粉色。

在這里插入圖片描述

組件內(nèi)部狀態(tài)更新:路徑2:組件是否應(yīng)該更新(shouldComponentUpdate)=》組件將要更新(componentWillUpdate)=》組件更新渲染(render)=》組件更新完成(componentDidUpdate)。

  • shouldComponentUpdate,未顯性聲明時默認(rèn)返回ture,返回false時組件無法進(jìn)行更新操作。也就無法執(zhí)行××××××××》組件將要更新(componentWillUpdate)=》組件更新渲染(render)=》組件更新完成。
shouldComponentUpdate(){
  return false;
}

強(qiáng)制更新:路徑3:我們可以調(diào)用this.forceUpdate()實現(xiàn)強(qiáng)制更新,這個api和setState一樣都是React自帶的,一般這個強(qiáng)制更新很少用。
組件將要更新(componentWillUpdate)=》組件更新渲染(render)=》組件更新完成(componentDidUpdate)。

父組件重新render:路徑1:在父組件執(zhí)行完render()之后會被觸發(fā)。還記得嗎?我們藍(lán)色的區(qū)域是更新的生命鉤子,也就是說第一次render()的時候不算,第二次及之后才會被觸發(fā)。(componentWillReceiveProps)

import React, { Component } from 'react'

export default class A extends Component {
  state={
    car:'奧迪'
  }
  changeCar= () => {
    this.setState({
      car:'奔馳'
    })
  }
  render() {
    return (
      <div>
        <div>我是組件A</div>
        <button onClick={this.changeCar}>換車</button>
        <B car={this.state.car}/>
      </div>
    )
  }
}

class B extends Component {
  //首次渲染不會被觸發(fā)
  componentWillReceiveProps(){
    console.log('componentWillReceiveProps')
  }
  render() {
    return (
      <div>
        我是組件B,我接收到的車是:{this.props.car}
      </div>
    )
  }
}

舊生命鉤子的總結(jié)

在這里插入圖片描述

新生命鉤子

當(dāng)你充分理解舊的生命鉤子之后,看下面這張圖對你來說應(yīng)該易如反掌。大體來說用來劃分的區(qū)塊方式一致,即:創(chuàng)建時、更新時【三條路徑】、卸載時。

在這里插入圖片描述

getDerivedSateFromProps

直譯:從props哪里獲得的派生的State

1.
state ={name:'佛系努力中……'}
//注意點1:需聲明為類的靜態(tài)方法《static》
static getDerivedStateFormProps(props,state){
  //可以讀取到props,state
  //注意點2:必須return一個state對象或者null
  return {name:'哈哈哈'} 
  //或者null
}

最后,this.state.name將會被渲染成‘哈哈哈’,直接更改了state的值,且任何操作不會改變該值。 

2.
state ={name:'佛系努力中……'}
static getDerivedStateFormProps(props,state){
  return null
}

如果return null 功能將不會受到影響 

3.此方法使用于state的值在任何時候取決于porps
state ={name:'佛系努力中……'}
static getDerivedStateFormProps((props,state){
  return props
}

總結(jié):這個生命周期鉤子會被用到情況很少,并且建議盡量避免使用,防止導(dǎo)致代碼冗余,并使組件難以維護(hù)。

getSnapshotBeforeUpdate

//在更新之前獲得一個快照
getSnapshotBeforeUpdate(prevProps,prevState){
    console.log("getSnapshotBeforeUpdate--",prevProps,prevState)
    return '一只小貓'
}

componentDidUpdate

//組件以及更新完畢,接收三個值,最后一個snapShot,即為getSnapshotBeforeUpdate返回值
componentDidUpdate(prevProps,prevState,snapShot){
    console.log("componentDidUpdate--",prevProps,prevState,snapShot)
 }

一個應(yīng)用場景
總結(jié):這個東西實際應(yīng)用場景也很少,嘿嘿!

在這里插入圖片描述

到此這篇關(guān)于淺談react新舊生命周期鉤子的文章就介紹到這了,更多相關(guān)react 生命周期鉤子內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • React18之update流程從零實現(xiàn)詳解

    React18之update流程從零實現(xiàn)詳解

    這篇文章主要為大家介紹了React18之update流程從零實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • React中Redux核心原理深入分析

    React中Redux核心原理深入分析

    這篇文章主要介紹了如何在React中Redux原理,目前redux在react中使用是最多的,所以我們需要將之前編寫的redux代碼,融入到react當(dāng)中去,本文給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • React路由跳轉(zhuǎn)的實現(xiàn)示例

    React路由跳轉(zhuǎn)的實現(xiàn)示例

    在React中,可以使用多種方法進(jìn)行路由跳轉(zhuǎn),本文主要介紹了React路由跳轉(zhuǎn)的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • React+TS+IntersectionObserver實現(xiàn)視頻懶加載和自動播放功能

    React+TS+IntersectionObserver實現(xiàn)視頻懶加載和自動播放功能

    通過本文的介紹,我們學(xué)習(xí)了如何使用 React + TypeScript 和 IntersectionObserver API 來實現(xiàn)一個視頻播放控制組件,該組件具有懶加載功能,只有在用戶滾動頁面且視頻進(jìn)入視口時才開始下載視頻資源,需要的朋友可以參考下
    2023-04-04
  • React-hooks中的useEffect使用步驟

    React-hooks中的useEffect使用步驟

    這篇文章主要介紹了React-hooks中的useEffect,對于React組件來說,主作用是根據(jù)數(shù)據(jù)(state/props)渲染UI,除此之外都是副作用(比如手動修改DOM、發(fā)送ajax請求),本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2022-05-05
  • 前端開發(fā)使用Ant Design項目評價

    前端開發(fā)使用Ant Design項目評價

    這篇文章主要為大家介紹了前端開發(fā)使用Ant Design項目評價,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • React中使用react-player 播放視頻或直播的方法

    React中使用react-player 播放視頻或直播的方法

    這篇文章主要介紹了React中使用react-player 播放視頻或直播,本文教大家如何使用react框架及創(chuàng)建實例的代碼,本文內(nèi)容簡短給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-01-01
  • React文字展開收起組件的實現(xiàn)示例

    React文字展開收起組件的實現(xiàn)示例

    本文主要介紹了React文字展開收起組件的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • React實現(xiàn)原生APP切換效果

    React實現(xiàn)原生APP切換效果

    最近需要使用 Hybrid 的方式開發(fā)一 個 APP,交互和原生 APP 相似并且需要 IM 通信,本文給大家介紹了使用React實現(xiàn)原生APP切換效果,文中通過代碼示例講解的非常詳細(xì),感興趣的小伙伴跟著小編一起來看看吧
    2025-01-01
  • React項目使用ES6解決方案及JSX使用示例詳解

    React項目使用ES6解決方案及JSX使用示例詳解

    這篇文章主要為大家介紹了React項目使用ES6解決方案及JSX使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12

最新評論