React Native組件的結構和生命周期

来源:http://www.cnblogs.com/Potato-lover/archive/2017/04/17/6723077.html
-Advertisement-
Play Games

React Native組件的結構和生命周期 一、組件的結構 1、導入引用 可以理解為C++編程中的頭文件。 導入引用包括導入react native定義的組件、API,以及自定義的組件。 1.1 導入組件 1.2 導入API 1.3 導入自定義組件 2、組件的聲明 組件的生命分為組件的定義和樣式。 ...


React Native組件的結構和生命周期

一、組件的結構

1、導入引用

可以理解為C++編程中的頭文件。

導入引用包括導入react native定義的組件、API,以及自定義的組件。

1.1 導入組件

 

1.2 導入API

 

1.3 導入自定義組件

 

2、組件的聲明

組件的生命分為組件的定義和樣式。組件的定義有各種組件的組成結構、方法的定義。

2.1 組件的定義

 

2.2 組件樣式

組件樣式的定義可以直接在組件的定義中的style中定義。但是對於樣式複雜的組件需要組件樣式。

 

3、組件的註冊或導出

3.1 註冊

AppRegistryJS運行所有React Native應用的入口。應用的根組件應當通過AppRegistry.registerComponent方法註冊自己,然後原生系統才可以載入應用的代碼包並且在啟動完成之後通過調用AppRegistry.runApplication來真正運行應用。

 

3.2 導出

導出是用module.exports語句聲明組件,讓組件可以被其他組件引用。可以理解為JAVA中變數的聲明,聲明時並不分配記憶體空間。

 

二、組件的生命周期

一個React Native組件從它被React Native框架載入,到最終被React Native框架卸載,會經歷一個完整的生命周期。

2.1 getInitialState

其函數原型為:

object getInitialState()

這個函數將在React Native組件被家在前調用一次。它的返回值會成為this.state的初始值。

2.2 getDefaultProps

其函數原型為:

object getDefaultProps()

這個函數在組件被創建時調用一次。它的返回值會成為this.props的初始值。在這之後,如果父組件指定了組件的props中的某些值,這些值將會與this.props的初始值合併,如果有相同的鍵,父組件指定的鍵將覆蓋初始值的鍵。

getDefaultProps()返回的任何複雜對象都將會在組件的各個實例間共用,而不是每個實例擁有一個拷貝。

2.3 componentWillMount

其函數原型為:

componentWillMount()

React Native組件的生命周期中,這個函數只會被執行一次。它在初始渲染(render函數被React Native框架調用執行)前被執行,當它執行之後,render函數會馬上被React Native框架調用執行。如果在這個函數里調用setState函數改變了某些狀態機變數的值,React Native框架不會執行渲染操作,而是等待這個函數執行完成後再執行初始渲染。

React Native組件的子組件也有componentWillMount函數,並且會在父組件的componentWillMount函數之後被調用。

這個函數無參數並且不需要任何返回值。

如果開發者需要從本地存儲中讀取數據用於顯示,那麼在這個函數里進行讀取是一個很好的時機。

2.4 componentDidMount

其函數原型為:

componentDidMount()

React Native組件的生命周期中,這個函數只會被執行一次。它在初始渲染執行完成後會馬上被調用。在React Native組件生命周期的這個時間點之後,開發者可以通過子組件的引用來訪問、操作任何子組件。React Native組件的子組件也有componentDidMount函數,並且會在父組件的componentDidMount函數之前被調用。

這個函數無參數並且不需要任何返回值。

如果React Native應用需要在程式啟動顯示初始界面後從網路側獲取數據,那麼把從網路側獲取數據的代碼放在這個函數里是一個不錯的選擇。

2.5 componentWillReceiveProps

其函數原型為:

componentWillReceiveProps(object nextProps)

React Native組件的初始渲染執行完成後,當React Native組件接收到新的props時,這個函數將被調用。這個函數接收一個object參數,object里的是新的props

如果新的props會倒置界面重新渲染,這個函數將在渲染前被執行。在這個函數中,老的props可以通過this.props訪問,新的props在傳入的object中。如果在這個函數中通過調用this.setState函數改變某些狀態機變數的值,React Native框架不會執行對這些狀態機變數改變的渲染,而是等componentWillReceiveProps函數執行完成後一起渲染。

2.6 shouldComponentUpdate

其函數原型為:

boolean  shouldComponentUpdate(object nextProps, object nextState)

React Native組件的初始渲染執行完成後,當React Native組件接收到新的props或者state時,這個函數將被調用。這個函數接收兩個object參數,其中第一個是新的props,第二個是新的state。這個函數需要返回一個布爾值,告訴React Native框架針對這次改變,React Native是否需要重新渲染本組件。如果次函數返回falseReact Native將不會重新渲染本組件,相應的本組件的componentWillUpdatecomponentDidUpdate函數也不會被調用。

React Native組件預設的shouldComponentUpdate函數總是返回true值。如果開發者遵從了“視狀態機變數為‘不可變的常量’”這個開發規則,那麼開發者可以提供自己的shouldComponentUpdate,在函數中比較新老版本的stateprops,判斷是否需要進行重新渲染。

通過這個函數來阻止無必要的重新渲染,是提高React Native應用程式性能的一大技巧。

2.7 componentWillUpdate

其函數原型為:

componentWillUpdate(object nextProps, object nextState)

React Native組件的初始渲染執行完成後,React Native框架在重新渲染React Native組件前會調用這個函數。開發者可以在這個函數中為即將發生的重新渲染做一些準備工作,但開發者不能在這個函數中通過this.setState再次改變狀態機變數的值。如果需要改變,則在componentWillReceiveProps函數中進行改變。

2.8 componentDidUpdate

其函數原型為:

componentDidUpdate(object preProps, object preState)

eact Native組件的初始渲染執行完成後,React Native框架在重新渲染React Native組件後會調用這個函數。傳入的兩個參數是渲染前的propsstate

2.9 componentWillUnmount

其函數原型為:

componentWillUnmount()

React Native組件被卸載前,這個函數將被執行。這個函數沒有參數。

如果React Native組件申請了某些資源或者訂閱了某些消息,那麼需要在這個函數中釋放資源,取消訂閱。 

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、進程 進程可以理解為一個應用程式;比如說打開 QQ,那麼在記憶體中就會為 QQ 分配一塊進程;打開微信,那麼在記憶體中就會為 微信 分配一塊進程;並且進程之間是相互獨立的 二、線程 1. 基本概念 線程是進程的基本單元(可以理解為一個進程中的各個操作);比如說 QQ,其中的很多操作,比如說發送文件, ...
  • 一,效果圖。 二,工程圖。 三,代碼。 RootViewController.h #import <UIKit/UIKit.h> @interface RootViewController : UIViewController @end RootViewController.m #import "R ...
  • 怕有些人不知道怎麼進入微信的新消息提示音功能,我這裡說下操作步驟: 打開微信 我 設置 新消息提醒 新消息提示音。 經過以上的步驟就進入了這樣的界面 具體實現的步驟。 難點之一:獲取到手機系統的提示音,並將它們顯示在一個listview裡面。 參考如下代碼: 將獲取到的消息提示音的名字,加入到arr ...
  • 首先在看這個博客之前, 你可以先看下這個博客,http://blog.csdn.net/harryweasley/article/details/50057707 裡面介紹了兩種方式來獲取應用程式的信息,一種是packageInfo,一種是ResolveInfo,通過packageInfo來獲取應用 ...
  • HashMap是java里比較常用的一個集合類,我們一般用來緩存一些處理後的結果。但當你做一個Android項目時,在代碼中定義這樣一個變數,實例化時,Eclipse卻給出了一個 performance 警告。 意思是說Map已經不用了,使用SparseArray<Object>代替,以獲取更好性能 ...
  • 關於博客園Android客戶端 作為一名經常逛博客園的C 開發者,發現博客園沒有官方的Android APP,其他第三方的APP要麼年代久遠,要麼功能不完善,所以決定自己動手寫一個博客園的第三方Android APP試一試,同時也給需要Android APP的朋友提供一個選擇。APP內容由博客園官方 ...
  • 待續 ...
  • 1.首先做好下邊的準備: 1.1 http://lbs.amap.com/ 註冊賬號 1.2 下載 定位sdk 和 地圖sdk 下載後是這樣的 1.3 對下載的進行解壓 將他們加入 中,對每個jar,右鍵-Add As Library. 此時 build.gradle生成 1.4 申請API Key ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...