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

淺談React中的元素、組件、實例和節(jié)點

 更新時間:2018年02月27日 14:25:05   作者:艾特老干部  
這篇文章主要介紹了淺談React中的元素、組件、實例和節(jié)點,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

React 中的元素、組件、實例和節(jié)點,是React中關(guān)系密切的4個概念,也是很容易讓React 初學(xué)者迷惑的4個概念。現(xiàn)在,老干部就來詳細地介紹這4個概念,以及它們之間的聯(lián)系和區(qū)別,滿足喜歡咬文嚼字、刨根問底的同學(xué)(老干部就是其中一員)的好奇心。

元素 (Element)

React 元素其實就是一個簡單JavaScript對象,一個React 元素和界面上的一部分DOM對應(yīng),描述了這部分DOM的結(jié)構(gòu)及渲染效果。一般我們通過JSX語法創(chuàng)建React 元素,例如:

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

element是一個React 元素。在編譯環(huán)節(jié),JSX 語法會被編譯成對React.createElement()的調(diào)用,從這個函數(shù)名上也可以看出,JSX語法返回的是一個React 元素。上面的例子編譯后的結(jié)果為:

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節(jié)點創(chuàng)建React 元素,前面的例子就是一個DOM類型的元素;組件類型的元素使用React 組件創(chuàng)建React 元素,例如:

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

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

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

對于DOM類型的元素,因為和頁面的DOM節(jié)點直接對應(yīng),所以React知道如何進行渲染。但是對于組件類型的元素,如buttonElement,React是無法直接知道應(yīng)該把buttonElement渲染成哪種結(jié)構(gòu)的頁面DOM,這時就需要組件自身提供React能夠識別的DOM節(jié)點信息,具體實現(xiàn)方式在介紹組件時會詳細介紹。

有了React 元素,我們應(yīng)該如何使用它呢?其實,絕大多數(shù)情況下,我們都不會直接使用React 元素,React 內(nèi)部會自動根據(jù)React 元素,渲染出最終的頁面DOM。更確切地說,React元素描述的是React虛擬DOM的結(jié)構(gòu),React會根據(jù)虛擬DOM渲染出頁面的真實DOM。

組件 (Component)

React 組件,應(yīng)該是大家最熟悉的React中的概念。React通過組件的思想,將界面拆分成一個個可以復(fù)用的模塊,每一個模塊就是一個React 組件。一個React 應(yīng)用由若干組件組合而成,一個復(fù)雜組件也可以由若干簡單組件組合而成。

React組件和React元素關(guān)系密切,React組件最核心的作用是返回React元素。這里你也許會有疑問:React元素不應(yīng)該是由React.createElement() 返回的嗎?但React.createElement()的調(diào)用本身也是需要有“人”負責(zé)的,React組件正是這個“責(zé)任人”。React組件負責(zé)調(diào)用React.createElement(),返回React元素,供React內(nèi)部將其渲染成最終的頁面DOM。

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

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

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

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

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

現(xiàn)在來考慮下面這個例子:

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'
    }
   },
  ]
 }
}

對于這個結(jié)構(gòu),React 知道如何渲染type = 'div' 和 type = 'p' 的節(jié)點,但不知道如何渲染type='Welcome'的節(jié)點,當(dāng)React 發(fā)現(xiàn)Welcome 是一個React 組件時(判斷依據(jù)是Welcome首字母為大寫),會根據(jù)Welcome組件返回的React 元素決定如何渲染W(wǎng)elcome節(jié)點。Welcome組件返回的React 元素為:

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

這個結(jié)構(gòu)中只包含DOM節(jié)點,React是知道如何渲染的。如果這個結(jié)構(gòu)中還包含其他組件節(jié)點,React 會重復(fù)上面的過程,繼續(xù)解析對應(yīng)組件返回的React 元素,直到返回的React 元素中只包含DOM節(jié)點為止。這樣的遞歸過程,讓React 獲取到頁面的完整DOM結(jié)構(gòu)信息,渲染的工作自然就水到渠成了。

另外,如果仔細思考的話,可以發(fā)現(xiàn),React 組件的復(fù)用,本質(zhì)上是為了復(fù)用這個組件返回的React 元素,React 元素是React 應(yīng)用的最基礎(chǔ)組成單位。

實例 (Instance)

這里的實例特指React組件的實例。React 組件是一個函數(shù)或類,實際工作時,發(fā)揮作用的是React 組件的實例對象。只有組件實例化后,每一個組件實例才有了自己的props和state,才持有對它的DOM節(jié)點和子組件實例的引用。在傳統(tǒng)的面向?qū)ο蟮拈_發(fā)方式中,實例化的工作是由開發(fā)者自己手動完成的,但在React中,組件的實例化工作是由React自動完成的,組件實例也是直接由React管理的。換句話說,開發(fā)者完全不必關(guān)心組件實例的創(chuàng)建、更新和銷毀。

節(jié)點 (Node)

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

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

PropTypes.node又是什么類型呢?這表明optionalNode是一個React 節(jié)點。React 節(jié)點是指可以被React渲染的數(shù)據(jù)類型,包括數(shù)字、字符串、React 元素,或者是一個包含這些類型數(shù)據(jù)的數(shù)組。例如:

// 數(shù)字類型的節(jié)點
function MyComponent(props) {
 return 1;
}

// 字符串類型的節(jié)點
function MyComponent(props) {
 return 'MyComponent';
}

// React元素類型的節(jié)點
function MyComponent(props) {
 return <div>React Element</div>;
}

// 數(shù)組類型的節(jié)點,數(shù)組的元素只能是其他合法的React節(jié)點
function MyComponent(props) {
 const element = <div>React Element</div>;
 const arr = [1, 'MyComponent', element];
 return arr;
}

// 錯誤,不是合法的React節(jié)點
function MyComponent(props) {
 const obj = { a : 1}
 return obj;
}

最后總結(jié)一下,React 元素和組件的概念最重要,也最容易混淆;React 組件實例的概念大家了解即可,幾乎使用不到;React 節(jié)點有一定使用場景,但看過本文后應(yīng)該也就不存在理解問題了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • react-beautiful-dnd 實現(xiàn)組件拖拽功能

    react-beautiful-dnd 實現(xiàn)組件拖拽功能

    這篇文章主要介紹了react-beautiful-dnd 實現(xiàn)組件拖拽功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • create-react-app中添加less支持的實現(xiàn)

    create-react-app中添加less支持的實現(xiàn)

    這篇文章主要介紹了react.js create-react-app中添加less支持的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • ReactNative實現(xiàn)的橫向滑動條效果

    ReactNative實現(xiàn)的橫向滑動條效果

    本文介紹了ReactNative實現(xiàn)的橫向滑動條效果,本文結(jié)合示例代碼給大家介紹的非常詳細,補充介紹了ReactNative基于寬度變化實現(xiàn)的動畫效果,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • React通過hook實現(xiàn)封裝表格常用功能

    React通過hook實現(xiàn)封裝表格常用功能

    這篇文章主要為大家詳細介紹了React通過hook封裝表格常用功能的使用,文中的示例代碼講解詳細,具有一定的借鑒價值,有需要的小伙伴可以參考下
    2023-12-12
  • ReactJS中不同類型的狀態(tài)詳解

    ReactJS中不同類型的狀態(tài)詳解

    這篇文章主要為大家介紹了ReactJS中不同類型的狀態(tài)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • React引入css的幾種方式及應(yīng)用小結(jié)

    React引入css的幾種方式及應(yīng)用小結(jié)

    這篇文章主要介紹了React引入css的幾種方式及應(yīng)用小結(jié),操作styled組件的樣式屬性,可在組件標簽上定義屬性、也可以通過attrs定義屬性,本文通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2024-03-03
  • 聊聊jenkins部署vue/react項目的問題

    聊聊jenkins部署vue/react項目的問題

    本文給大家介紹了jenkins部署vue/react項目的問題,文末給大家提到了centOS安裝jenkins的腳本,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2022-02-02
  • React中的Hooks進階理解教程

    React中的Hooks進階理解教程

    這篇文章主要介紹了React中的Hooks進階理解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • react實現(xiàn)數(shù)據(jù)監(jiān)聽方式

    react實現(xiàn)數(shù)據(jù)監(jiān)聽方式

    這篇文章主要介紹了react實現(xiàn)數(shù)據(jù)監(jiān)聽方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • react組件的創(chuàng)建與更新實現(xiàn)流程詳解

    react組件的創(chuàng)建與更新實現(xiàn)流程詳解

    React組件分為函數(shù)組件與class組件;函數(shù)組件是無狀態(tài)組件,class稱為類組件;函數(shù)組件只有props,沒有自己的私有數(shù)據(jù)和生命周期函數(shù);class組件有自己私有數(shù)據(jù)(this.state)和生命周期函數(shù)
    2022-10-10

最新評論