React——組件的生命周期函數

来源:http://www.cnblogs.com/QxQstar/archive/2017/09/28/7608219.html
-Advertisement-
Play Games

每一個組件都有一些生命周期函數。 當組件實例被創建並且會插入到DOM中,下麵這些函數會被調用 constructor componentWillMount render componentDidMount 改變組件的state或props會導致更新,當重新渲染組件時會調用下麵這些方法 compone ...


每一個組件都有一些生命周期函數。

當組件實例被創建並且會插入到DOM中,下麵這些函數會被調用

constructor

componentWillMount

render

componentDidMount

改變組件的stateprops會導致更新,當重新渲染組件時會調用下麵這些方法

componentWillReceiveProps

shouldComponentUpdate

componentWillUpdate

render

componentDidUpdate

當組件從DOM中移除,會調用下麵的方法

componentWillUnmount

一.render()

render方法是必須的,render的返回值是下麵的類型:
(1)react元素:要麼是自定義的組件要麼是原生的DOM組件
(2)字元串或者數字:會被渲染成DOM中的文本節點
(3)Portals:通過ReactDOM.createPortal創建
(4)null:什麼都不會渲染
(5)Boolean:什麼都不渲染
(6)包含多個元素的數組

render(){
    return [
        <li key='1'>1</li>,
        <li key='2'>2</li>
    ]
}

 

 render方法應該是簡單的,在render中不能修改組件的state,每一次調用render都會返回一個新的結果。並且在render中也不能與瀏覽器進行交互,如果需要與瀏覽器交互,就在componentDidMount或者其他生命周期函數中執行。

二.constructor(props)

react組件的構造函數在組件裝載之前調用。如果沒有顯示的定義constructor,那麼在實例化組件時會調用預設的constructor如果在React.Component的子類中顯示的定義了constructor,那麼就要在constructor中最開始調用super(props).
在構造函數中實例化state是一個很好的選擇。下麵舉例一段代碼

 

constructor(props) {
  super(props);
  this.state = {
    color: props.initialColor
  };
}

 

 在react中使用props初始化state是合法的,但是這存在一個問題:當props被更新時,state並不會被更新。解決的方法是:在組件的componentWillReceiveProps(nextProps)中用新的props更新state。雖然這能解決問題,但是並不推薦,推薦把state提升到最近的公共父組件中

 

三.componentWillMount()

當裝載發生之前會立即調用componentWillMount,componentWillMount會在調用render之前被調用,所有在componentWillMount中修改state,不會導致組件的重新渲染。伺服器端渲染才會調用這個方法,所有推薦通過constructor代替這個方法。

四.componentDidMount()

當組件被裝載完成會立即觸發componentDidMount,在這個函數中修改state被導致組件重新渲染。組件被裝載之後才能操作DOM。如果你需要載入遠程數據,在這個地方發送網路請求是個不錯的主意.

五.componentWillReceiveProps(nextProps)

當已經被轉載的組件接受新的props之前componentWillReceiveProps會被觸發。如果你需要更新state去響應props的更新,可以在這裡通過setState方法更新state。當組件首次接受到props,這個方法不會被調用.
註意:props沒有被改變也可能會調用這個方法,所有在這個方法中將當前的props去next props進行比較是很有必要的。

六.shouldComponentUpdate(nextState,nextProps)

當新的props或state被接受,在渲染之前會調用shouldComponentUpdate,這個方法預設是返回true,初次渲染和使用forceUpdate,不會調用這個方法。如果shouldComponentUpdate返回false,之後的componentWillUpdate,render以及componentDidMount不會被調用,組件以及他的子組件不會被重新渲染。

七.componentWillUpdate(nextProps, nextState)

當接受到新的props或state,在重新渲染之前會立即調用這個方法。在這個方法中不能this.setState(),初次渲染不會調用這個方法

八.componentDidUpdate(prevProps, prevState)

當更新完成之後會立即調用這個方法,初次渲染不會調用這個方法。當組件被更新之後可以在這裡操作DOM,當你發現現在的props與之前的props不一樣,在這裡發送網路請求是個不錯的主意

九.componentWillUnmount()

組件被摧毀之前會立即調用這個方法,在這個方法中可以做一些必要的清理

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前一講主要說了jenkins分發的好處《jenkins~集群分發功能和職責處理》,它可以讓具體的節點乾自己具體的事,比如windows環境下的節點,它只負責編譯,發佈windows的生態環境的項目;而linux節點主要負責和它相關的項目,如nodejs,.net core,java,php,pyth ...
  • 上手前準備工作 支持操作系統:windows、OS X、Linux。實例採用.net、.net core sdk。 The .NET Core SDK command line tools. The .NET framework 4.5 (for OS X and Linux, the open s ...
  • 單例模式是JavaScript中最常見的一種模式,通過這種模式可以為我們提供一個命名空間,例如jQuery庫的命名空間為jQuery或$。命名空間的使用是為了讓代碼更加整潔,在多人協作開發的情況下,不同的人定義的變數很有可能重覆,此時就需要使用命名空間來約束每個人定義的變數,使相同名稱的變數放在不同... ...
  • 今天給某公司做招聘專頁。早上完成設計圖,下午開始排版。頁面套用了我之前做的某人才局的招聘頁面,導航欄、banner 很快就出來了。這次內容里我有些地方用了列表,當然要用 <ul> <li> 標簽。列表項(小圓點)做成綠色的小正方塊,這時我想是不是有一個 CSS 屬性用來自定義列表項。 不用不知道,還 ...
  • 一、WebApp介紹 1.初始界面 2.搜索結果頁面 二、項目代碼 1.項目目錄 app app.component.ts app.component.css app.component.html app.module.ts 2.app.component.html 3.app.component. ...
  • 在講之前先談談大致步驟:安裝nodejs -> 全局安裝grunt -> 項目創建package.json --> 項目安裝grunt以及grunt插件 -> 配置Gruntfile.js -> 運行任務 1.安裝Node 我們開始之前需要安裝Nodejs,如果沒有安裝的 傳送門 安裝好了之後,查看 ...
  • history 對象保存著用戶上網的瀏覽記錄,從視窗被打開的時刻算起 history.go(num); num 可以取值正負整數,負數表示向後跳轉 ( 後退 ) ,正數表示向前跳轉 ( 前進 ) ,num 表示跳轉的頁面數 history.go("xxx.com"); 跳轉到 xxx.com 頁面 ...
  • 用於識別用戶客戶端瀏覽器 檢測插件 name: 插件的名字 description: 插件的描述 filename: 插件的文件名 length: 插件所處理的 MIME 類型數量 註冊處理程式 registerContentHandler() 接收 3 個參數: 要處理的 MIME 類型、可以處理 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...