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

React生命周期原理與用法踩坑筆記

 更新時(shí)間:2020年04月28日 09:38:49   作者:xiaoping  
這篇文章主要介紹了React生命周期原理與用法,結(jié)合實(shí)例形式總結(jié)分析了react生命周期原理、用法及相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了React生命周期原理與用法。分享給大家供大家參考,具體如下:

React生命周期

生命周期概覽

生命周期的狀態(tài)

組件的生命周期可分成三個(gè)狀態(tài):

  • Mounting:已插入真實(shí) DOM
  • Updating:正在被重新渲
  • Unmounting:已移出真實(shí) DOM
  • componentWillMount 在渲染前調(diào)用,在客戶端也在服務(wù)端。

生命周期介紹

componentDidMount :

在第一次渲染后調(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)。

componentWillReceiveProps

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

shouldComponentUpdate

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

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

componentWillUpdate

在組件接收到新的props或者state但還沒有render時(shí)被調(diào)用。在初始化時(shí)不會(huì)被調(diào)用。

componentDidUpdate

在組件完成更新后立即調(diào)用。在初始化時(shí)不會(huì)被調(diào)用。

componentWillUnmount

在組件從 DOM 中移除之前立刻被調(diào)用。

代碼示意

class Content extends React.Component {
 componentWillMount() {
   console.log('Component WILL MOUNT!')
 }
 componentDidMount() {
    console.log('Component DID MOUNT!')
 }
 componentWillReceiveProps(newProps) {
    console.log('Component WILL RECEIVE PROPS!')
 }
 shouldComponentUpdate(newProps, newState) {
    return true;
 }
 componentWillUpdate(nextProps, nextState) {
    console.log('Component WILL UPDATE!');
 }
 componentDidUpdate(prevProps, prevState) {
    console.log('Component DID UPDATE!')
 }
 componentWillUnmount() {
     console.log('Component WILL UNMOUNT!')
 }
 

React16.3生命周期

安裝

在創(chuàng)建組件的實(shí)例并將其插入DOM時(shí),將按以下順序調(diào)用這些方法:

constructor()

React組件的構(gòu)造函數(shù)在安裝之前被調(diào)用。在實(shí)現(xiàn)React.Component子類的構(gòu)造函數(shù)時(shí),應(yīng)該super(props)在任何其他語句之前調(diào)用。否則,this.props將在構(gòu)造函數(shù)中未定義,這可能導(dǎo)致錯(cuò)誤。

通常,在React中,構(gòu)造函數(shù)僅用于兩個(gè)目的:

通過分配對(duì)象來初始化本地狀態(tài)this.state。

將事件處理程序方法綁定到實(shí)例。

不應(yīng)該打電話setState()給constructor()。相反,如果您的組件需要使用本地狀態(tài),請(qǐng)直接在構(gòu)造函數(shù)中指定初始狀態(tài)this.state。

構(gòu)造函數(shù)是his.state直接分配的唯一位置。在所有其他方法中,需要使用this.setState()。

static getDerivedStateFromProps()

getDerivedStateFromProps在調(diào)用render方法之前調(diào)用,無論是在初始安裝還是后續(xù)更新。它應(yīng)該返回一個(gè)更新狀態(tài)的對(duì)象,或者返回null以不更新任何狀態(tài)。

render()

render()方法是類組件中唯一必需的方法。

調(diào)用時(shí),它應(yīng)檢查this.props并this.state返回以下類型之一:

  • React elements。通常通過JSX創(chuàng)建。
  • Arrays and fragments。讓您從渲染中返回多個(gè)元素。有關(guān)更多詳細(xì)信息,請(qǐng)參閱片段文檔。
  • Portals。
  • 字符串和數(shù)字。它們?cè)贒OM中呈現(xiàn)為文本節(jié)點(diǎn)。
  • 布爾或null。什么都沒有。

該render()函數(shù)應(yīng)該無狀態(tài)的,這意味著它不會(huì)修改組件狀態(tài),每次調(diào)用時(shí)都返回相同的結(jié)果,并且它不直接與瀏覽器交互。

如果您需要與瀏覽器進(jìn)行交互,請(qǐng)執(zhí)行componentDidMount()或其他生命周期方法。保持render()純粹使組件更容易思考。

如果shouldComponentUpdate()返回false,則render()不會(huì)被調(diào)用

componentDidMount()

  • componentDidMount()在安裝組件(插入樹中)后立即調(diào)用。需要DOM節(jié)點(diǎn)的初始化應(yīng)該放在這里。如果需要從遠(yuǎn)程端點(diǎn)加載數(shù)據(jù),這是實(shí)例化網(wǎng)絡(luò)請(qǐng)求的好地方。
  • 此方法是設(shè)置任何訂閱的好地方。如果您這樣做,請(qǐng)不要忘記取消訂閱componentWillUnmount()。
  • 您可以在componentDidMount()立即使用this.setState()。它將觸發(fā)額外的渲染,但它將在瀏覽器更新屏幕之前發(fā)生。這保證即使render()在這種情況下將被調(diào)用兩次,用戶也不會(huì)看到中間狀態(tài)。請(qǐng)謹(jǐn)慎使用此模式,因?yàn)樗ǔ?huì)導(dǎo)致性能問題。在大多數(shù)情況下,您應(yīng)該能夠分配初始狀態(tài)constructor()。但是,當(dāng)您需要在渲染依賴于其大小或位置的東西之前測(cè)量DOM節(jié)點(diǎn)時(shí),可能需要對(duì)模態(tài)和工具提示等情況進(jìn)行處理。

這些方法被認(rèn)為是遺留的,應(yīng)該在新代碼中避免它們:

UNSAFE_componentWillMount()

更新

props or state 的更改可能導(dǎo)致更新。重新渲染組件時(shí),將按以下順序調(diào)用這些方法:

static getDerivedStateFromProps()
render()
getSnapshotBeforeUpdate()
getSnapshotBeforeUpdate(prevProps, prevState)

getSnapshotBeforeUpdate()在最近呈現(xiàn)的輸出被提交到例如DOM之前調(diào)用。它使得組件可以在可能更改之前從DOM捕獲一些信息(例如滾動(dòng)位置)。此生命周期返回的任何值都將作為參數(shù)傳遞給componentDidUpdate()。

此用例并不常見,但它可能出現(xiàn)在需要以特殊方式處理滾動(dòng)位置的聊天線程等UI中。

官網(wǎng)的例子

class ScrollingList extends React.Component {
 constructor(props) {
  super(props);
  this.listRef = React.createRef();
 }

 getSnapshotBeforeUpdate(prevProps, prevState) {
  // Are we adding new items to the list?
  // Capture the scroll position so we can adjust scroll later.
  if (prevProps.list.length < this.props.list.length) {
   const list = this.listRef.current;
   return list.scrollHeight - list.scrollTop;
  }
  return null;
 }

 componentDidUpdate(prevProps, prevState, snapshot) {
  // If we have a snapshot value, we've just added new items.
  // Adjust scroll so these new items don't push the old ones out of view.
  // (snapshot here is the value returned from getSnapshotBeforeUpdate)
  if (snapshot !== null) {
   const list = this.listRef.current;
   list.scrollTop = list.scrollHeight - snapshot;
  }
 }

 render() {
  return (
   <div ref={this.listRef}>{/* ...contents... */}</div>
  );
 }
}

componentDidUpdate()

componentDidUpdate()更新發(fā)生后立即調(diào)用。初始渲染不會(huì)調(diào)用此方法。

將此作為在更新組件時(shí)對(duì)DOM進(jìn)行操作的機(jī)會(huì)。只要您將當(dāng)前道具與之前的道具進(jìn)行比較(例如,如果道具未更改,則可能不需要網(wǎng)絡(luò)請(qǐng)求),這也是進(jìn)行網(wǎng)絡(luò)請(qǐng)求的好地方。

componentDidUpdate(prevProps) {
 // Typical usage (don't forget to compare props):
 if (this.props.userID !== prevProps.userID) {
  this.fetchData(this.props.userID);
 }
}

componentDidUpdate()但要注意,必須在一個(gè)條件下被包裹就像上面的例子中,否則會(huì)導(dǎo)致無限循環(huán)。它還會(huì)導(dǎo)致額外的重新渲染,雖然用戶不可見,但會(huì)影響組件性能。

componentDidUpdate():如果shouldComponentUpdate()返回false,則不會(huì)被調(diào)用。

這些方法被認(rèn)為是遺留的,您應(yīng)該在新代碼中避免它們:

UNSAFE_componentWillUpdate()

UNSAFE_componentWillReceiveProps()

卸載

從DOM中刪除組件時(shí)調(diào)用此方法:

componentWillUnmount()

componentWillUnmount()在卸載和銷毀組件之前立即調(diào)用。在此方法中執(zhí)行任何必要的清理,例如使計(jì)時(shí)器無效,取消網(wǎng)絡(luò)請(qǐng)求或清除在其中創(chuàng)建的任何訂閱componentDidMount()。

不應(yīng)該調(diào)用setState(),componentWillUnmount()因?yàn)榻M件永遠(yuǎn)不會(huì)被重新呈現(xiàn)。卸載組件實(shí)例后,將永遠(yuǎn)不會(huì)再次安裝它。

錯(cuò)誤處理

在渲染期間,生命周期方法或任何子組件的構(gòu)造函數(shù)中發(fā)生錯(cuò)誤時(shí),將調(diào)用這些方法。

static getDerivedStateFromError()

static getDerivedStateFromError(error)

在后代組件拋出錯(cuò)誤后調(diào)用此生命周期。它接收作為參數(shù)拋出的錯(cuò)誤,并應(yīng)返回值以更新狀態(tài)。

componentDidCatch()

componentDidCatch(error, info)

在后代組件拋出錯(cuò)誤后調(diào)用此生命周期。它接收兩個(gè)參數(shù):

error - 拋出的錯(cuò)誤。

info- componentStack包含鍵的對(duì)象,其中包含有關(guān)哪個(gè)組件引發(fā)錯(cuò)誤的信息。

如果發(fā)生錯(cuò)誤,可以componentDidCatch()通過調(diào)用呈現(xiàn)回退UI setState,但在將來的版本中將不推薦使用。使用static getDerivedStateFromError()處理回退,而不是渲染。

componentDidCatch()在“提交”階段被調(diào)用,因此允許副作用。它應(yīng)該用于記錄錯(cuò)誤之類的事情:

class ErrorBoundary extends React.Component {
 constructor(props) {
  super(props);
  this.state = { hasError: false };
 }

 static getDerivedStateFromError(error) {
  // Update state so the next render will show the fallback UI.
  return { hasError: true };
 }

 componentDidCatch(error, info) {
  // Example "componentStack":
  //  in ComponentThatThrows (created by App)
  //  in ErrorBoundary (created by App)
  //  in div (created by App)
  //  in App
  logComponentStackToMyService(info.componentStack);
 }

 render() {
  if (this.state.hasError) {
   // You can render any custom fallback UI
   return <h1>Something went wrong.</h1>;
  }
  return this.props.children; 
 }
}

希望本文所述對(duì)大家react程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 詳解React的回調(diào)渲染模式

    詳解React的回調(diào)渲染模式

    這篇文章主要介紹了詳解React的回調(diào)渲染模式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • React實(shí)現(xiàn)父組件調(diào)用子組件的兩種寫法

    React實(shí)現(xiàn)父組件調(diào)用子組件的兩種寫法

    react通信分很多種,比如:父子通信,兄弟通信等等,這里我們就簡(jiǎn)單說一下父子通信,父子通信分為:父組件調(diào)用子組件里面的方法;子組件調(diào)用子組件里面的方法,這里我們著重說一下父組件調(diào)用子組件,需要的朋友可以參考下
    2024-04-04
  • react-router-dom6(對(duì)比?router5)快速入門指南

    react-router-dom6(對(duì)比?router5)快速入門指南

    這篇文章主要介紹了快速上手react-router-dom6(對(duì)比?router5),通過本文學(xué)習(xí)最新的react-router-dom?v6版本的路由知識(shí),并且會(huì)與v5老版本進(jìn)行一些對(duì)比,需要的朋友可以參考下
    2022-08-08
  • 關(guān)于react的代理配置(可配置多個(gè)代理)

    關(guān)于react的代理配置(可配置多個(gè)代理)

    這篇文章主要介紹了關(guān)于react的代理配置(可配置多個(gè)代理),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 淺談React前后端同構(gòu)防止重復(fù)渲染

    淺談React前后端同構(gòu)防止重復(fù)渲染

    這篇文章主要介紹了淺談React前后端同構(gòu)防止重復(fù)渲染,首先解釋React前后端同構(gòu)、React首屏渲染的概念。然后通過這2個(gè)概念解決服務(wù)端渲染完成后瀏覽器端重復(fù)渲染的問題。有興趣的可以了解一下
    2018-01-01
  • 深入理解react 組件類型及使用場(chǎng)景

    深入理解react 組件類型及使用場(chǎng)景

    這篇文章主要介紹了深入理解react 組件類型及使用場(chǎng)景,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-03-03
  • react項(xiàng)目中使用react-dnd實(shí)現(xiàn)列表的拖拽排序功能

    react項(xiàng)目中使用react-dnd實(shí)現(xiàn)列表的拖拽排序功能

    這篇文章主要介紹了react項(xiàng)目中使用react-dnd實(shí)現(xiàn)列表的拖拽排序,本文結(jié)合實(shí)例代碼講解react-dnd是如何實(shí)現(xiàn),代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • React不能將useMemo設(shè)置為默認(rèn)方法原因詳解

    React不能將useMemo設(shè)置為默認(rèn)方法原因詳解

    這篇文章主要為大家介紹了React不能將useMemo設(shè)置為默認(rèn)方法原因詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2022-07-07
  • react實(shí)現(xiàn)換膚功能的示例代碼

    react實(shí)現(xiàn)換膚功能的示例代碼

    這篇文章主要介紹了react實(shí)現(xiàn)換膚功能的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • react?Table準(zhǔn)備Spin?Empty?ConfigProvider組件實(shí)現(xiàn)

    react?Table準(zhǔn)備Spin?Empty?ConfigProvider組件實(shí)現(xiàn)

    這篇文章主要為大家介紹了react?Table準(zhǔn)備Spin、Empty、ConfigProvider組件實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2023-02-02

最新評(píng)論