亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

React 深入系列1:React 中的元素、組件、實例和節(jié)點

LeviDing / 2617人閱讀

摘要:中的元素組件實例和節(jié)點,是中關系密切的個概念,也是很容易讓初學者迷惑的個概念。組件和元素關系密切,組件最核心的作用是返回元素。只有組件實例化后,每一個組件實例才有了自己的和,才持有對它的節(jié)點和子組件實例的引用。

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

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

元素 (Element)

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

const element = 

Hello, world

;

element是一個React 元素。在編譯環(huán)節(jié),JSX 語法會被編譯成對React.createElement()的調用,從這個函數(shù)名上也可以看出,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節(jié)點創(chuàng)建React 元素,前面的例子就是一個DOM類型的元素;組件類型的元素使用React 組件創(chuàng)建React 元素,例如:

const buttonElement = ;

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

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

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

有了React 元素,我們應該如何使用它呢?其實,絕大多數(shù)情況下,我們都不會直接使用React 元素,React 內部會自動根據(jù)React 元素,渲染出最終的頁面DOM。更確切地說,React元素描述的是React虛擬DOM的結構,React會根據(jù)虛擬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元素的函數(shù):

function Welcome(props) {
  return 

Hello, {props.name}

; }

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

class Welcome extends React.Component {
  render() {
    return 

Hello, {this.props.name}

; } }

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

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

class Home extends React.Component {
  render() {
    return (
      

Anything you like

) } }

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

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

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

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

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

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

實例 (Instance)

這里的實例特指React組件的實例。React 組件是一個函數(shù)或類,實際工作時,發(fā)揮作用的是React 組件的實例對象。只有組件實例化后,每一個組件實例才有了自己的props和state,才持有對它的DOM節(jié)點和子組件實例的引用。在傳統(tǒng)的面向對象的開發(fā)方式中,實例化的工作是由開發(fā)者自己手動完成的,但在React中,組件的實例化工作是由React自動完成的,組件實例也是直接由React管理的。換句話說,開發(fā)者完全不必關心組件實例的創(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 
React Element
; } // 數(shù)組類型的節(jié)點,數(shù)組的元素只能是其他合法的React節(jié)點 function MyComponent(props) { const element =
React Element
; const arr = [1, "MyComponent", element]; return arr; } // 錯誤,不是合法的React節(jié)點 function MyComponent(props) { const obj = { a : 1} return obj; }

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

下篇預告:

React 深入系列2:組件分類

我的新書《React進階之路》已上市,請大家多多支持!
鏈接:京東 當當

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://www.ezyhdfw.cn/yun/95173.html

相關文章

  • React 深入系列1:React 中的元素、組件實例節(jié)點

    摘要:中的元素組件實例和節(jié)點,是中關系密切的個概念,也是很容易讓初學者迷惑的個概念。組件和元素關系密切,組件最核心的作用是返回元素。只有組件實例化后,每一個組件實例才有了自己的和,才持有對它的節(jié)點和子組件實例的引用。 文:徐超,《React進階之路》作者授權發(fā)布,轉載請注明作者及出處 React 深入系列,深入講解了React中的重點概念、特性和模式等,旨在幫助大家加深對React的理解...

    techstay 評論0 收藏0
  • React前端學習小結

    摘要:正式開始系統(tǒng)地學習前端已經(jīng)三個多月了,感覺前端知識體系龐雜但是又非常有趣。更新一個節(jié)點需要做的事情有兩件,更新頂層標簽的屬性,更新這個標簽包裹的子節(jié)點。 正式開始系統(tǒng)地學習前端已經(jīng)三個多月了,感覺前端知識體系龐雜但是又非常有趣。前端演進到現(xiàn)在對開發(fā)人員的代碼功底要求已經(jīng)越來越高,幾年前的前端開發(fā)還是大量操作DOM,直接與用戶交互,而React、Vue等MVVM框架的出現(xiàn),則幫助開發(fā)者從...

    iOS122 評論0 收藏0
  • JavaScript 是如何工作的:編寫自己的 Web 開發(fā)框架 + React 及其虛擬 DOM

    摘要:與大多數(shù)全局對象不同,沒有構造函數(shù)。為什么要設計更加有用的返回值早期寫法寫法函數(shù)式操作早期寫法寫法可變參數(shù)形式的構造函數(shù)一般寫法寫法當然還有很多,大家可以自行到上查看什么是代理設計模式代理模式,為其他對象提供一種代理以控制對這個對象的訪問。 這是專門探索 JavaScript 及其所構建的組件的系列文章的第 19 篇。 如果你錯過了前面的章節(jié),可以在這里找到它們: 想閱讀更多優(yōu)質文章請...

    余學文 評論0 收藏0
  • 深入React知識點整理(一)

    摘要:以我自己的理解,函數(shù)式編程就是以函數(shù)為中心,將大段過程拆成一個個函數(shù),組合嵌套使用。越來越多的跡象表明,函數(shù)式編程已經(jīng)不再是學術界的最愛,開始大踏步地在業(yè)界投入實用。也許繼面向對象編程之后,函數(shù)式編程會成為下一個編程的主流范式。 使用React也滿一年了,從剛剛會使用到逐漸探究其底層實現(xiàn),以便學習幾招奇技淫巧從而在自己的代碼中使用,寫出高效的代碼。下面整理一些知識點,算是React看書...

    Gilbertat 評論0 收藏0
  • 從代碼實踐潛入React內部,深入diff

    摘要:概述協(xié)調,調解本身不存在公共的。安裝的確切結果有時在源代碼中稱為取決于渲染器,可以是節(jié)點,字符串或表示原生視圖。關鍵的缺失部分是對更新的支持。為避免混淆,我們將和的實例叫做內部實例。但是,內部實例樹包含復合和主機內部實例。 本節(jié)是 stack reconciler程序的實現(xiàn)說明的集合。 本文有一定的技術含量,要對React公共API以及它如何分為核心,渲染器和協(xié)調(和解,reconci...

    leap_frog 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<