淺談React中的元素、組件、執行個體和節點,淺談react

來源:互聯網
上載者:User

淺談React中的元素、組件、執行個體和節點,淺談react

React 深入系列,深入講解了React中的重點概念、特性和模式等,旨在協助大家加深對React的理解,以及在項目中更加靈活地使用React。

React 中的元素、組件、執行個體和節點,是React中關係密切的4個概念,也是很容易讓React 初學者迷惑的4個概念。現在,老乾部就來詳細地介紹這4個概念,以及它們之間的聯絡和區別,滿足喜歡咬文嚼字、刨根問底的同學(老乾部就是其中一員)的好奇心。

元素 (Element)

React 元素其實就是一個簡單JavaScript對象,一個React 元素和介面上的一部分DOM對應,描述了這部分DOM的結構及渲染效果。一般我們通過JSX文法建立React 元素,例如:

const element = <h1 className='greeting'>Hello, world</h1>;

element是一個React 元素。在編譯環節,JSX 文法會被編譯成對React.createElement()的調用,從這個函數名上也可以看出,JSX文法返回的是一個React 元素。上面的例子編譯後的結果為:

const element = React.createElement( 'h1', {className: 'greeting'}, 'Hello, world!');

最終,element的值是類似下面的一個簡單JavaScript對象:

const element = { type: 'h1', props: {  className: 'greeting',  children: 'Hello, world' }}

React 元素可以分為兩類:DOM類型的元素和組件類型的元素。DOM類型的元素使用像h1、div、p等DOM節點建立React 元素,前面的例子就是一個DOM類型的元素;組件類型的元素使用React 組件建立React 元素,例如:

const buttonElement = <Button color='red'>OK</Button>;

buttonElement就是一個組件類型的元素,它的值是:

const buttonElement = { type: 'Button', props: {  color: 'red',  children: 'OK' }}

對於DOM類型的元素,因為和頁面的DOM節點直接對應,所以React知道如何進行渲染。但是對於組件類型的元素,如buttonElement,React是無法直接知道應該把buttonElement渲染成哪種結構的頁面DOM,這時就需要組件自身提供React能夠識別的DOM節點資訊,具體實現方式在介紹組件時會詳細介紹。

有了React 元素,我們應該如何使用它呢?其實,絕大多數情況下,我們都不會直接使用React 元素,React 內部會自動根據React 元素,渲染出最終的頁面DOM。更確切地說,React元素描述的是React虛擬DOM的結構,React會根據虛擬DOM渲染出頁面的真實DOM。

組件 (Component)

React 組件,應該是大家最熟悉的React中的概念。React通過組件的思想,將介面拆分成一個個可以複用的模組,每一個模組就是一個React 組件。一個React 應用由若干組件組合而成,一個複雜組件也可以由若干簡單組件組合而成。

React組件和React元素關係密切,React組件最核心的作用是返回React元素。這裡你也許會有疑問:React元素不應該是由React.createElement() 返回的嗎?但React.createElement()的調用本身也是需要有“人”負責的,React組件正是這個“責任人”。React組件負責調用React.createElement(),返回React元素,供React內部將其渲染成最終的頁面DOM。

既然組件的核心作用是返回React元素,那麼最簡單的組件就是一個返回React元素的函數:

function Welcome(props) { return <h1>Hello, {props.name}</h1>;}

Welcome是一個用函數定義的組件。如果使用類(class)定義組件,返回React元素的工作具體就由組件的render方法承擔,例如:

class Welcome extends React.Component { render() {  return <h1>Hello, {this.props.name}</h1>; }}

其實,使用類定義的組件,render方法是唯一必需的方法,其他組件的生命週期方法都只不過是為render服務而已,都不是必需的。

現在來考慮下面這個例子:

class Home extends React.Component { render() {  return (   <div>    <Welcome name='老乾部' />    <p>Anything you like</p>   </div>  ) }}

Home 組件使用了Welcome組件,返回的React元素為:

{ type: 'div', props: {  children: [   {    type: 'Welcome',    props: {     name: '老乾部'    }   },   {    type: 'p',    props: {     children: 'Anything you like'    }   },  ] }}

對於這個結構,React 知道如何渲染type = 'div' 和 type = 'p' 的節點,但不知道如何渲染type='Welcome'的節點,當React 發現Welcome 是一個React 組件時(判斷依據是Welcome首字母為大寫),會根據Welcome組件返回的React 元素決定如何渲染Welcome節點。Welcome組件返回的React 元素為:

{ type: 'h1', props: {  children: 'Hello, 老乾部' }}

這個結構中只包含DOM節點,React是知道如何渲染的。如果這個結構中還包含其他元件節點,React 會重複上面的過程,繼續解析對應組件返回的React 元素,直到返回的React 元素中只包含DOM節點為止。這樣的遞迴過程,讓React 擷取到頁面的完整DOM結構資訊,渲染的工作自然就水到渠成了。

另外,如果仔細思考的話,可以發現,React 組件的複用,本質上是為了複用這個組件返回的React 元素,React 元素是React 應用的最基礎組成單位。

執行個體 (Instance)

這裡的執行個體特指React組件的執行個體。React 組件是一個函數或類,實際工作時,發揮作用的是React 組件的執行個體對象。只有組件執行個體化後,每一個組件執行個體才有了自己的props和state,才持有對它的DOM節點和子組件執行個體的引用。在傳統的物件導向的開發方式中,執行個體化的工作是由開發人員自己手動完成的,但在React中,組件的執行個體化工作是由React自動完成的,組件執行個體也是直接由React管理的。換句話說,開發人員完全不必關心組件執行個體的建立、更新和銷毀。

節點 (Node)

在使用PropTypes校正組件屬性時,有這樣一種類型:

MyComponent.propTypes = {  optionalNode: PropTypes.node,}

PropTypes.node又是什麼類型呢?這表明optionalNode是一個React 節點。React 節點是指可以被React渲染的資料類型,包括數字、字串、React 元素,或者是一個包含這些類型資料的數組。例如:

// 數字類型的節點function MyComponent(props) { return 1;}// 字串類型的節點function MyComponent(props) { return 'MyComponent';}// React元素類型的節點function MyComponent(props) { return <div>React Element</div>;}// 數群組類型的節點,數組的元素只能是其他合法的React節點function MyComponent(props) { const element = <div>React Element</div>; const arr = [1, 'MyComponent', element]; return arr;}// 錯誤,不是合法的React節點function MyComponent(props) { const obj = { a : 1} return obj;}

最後總結一下,React 元素和組件的概念最重要,也最容易混淆;React 組件執行個體的概念大家瞭解即可,幾乎使用不到;React 節點有一定使用情境,但看過本文後應該也就不存在理解問題了。

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.