亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

淺談React中的元素、組件、實例和節點

2019-11-19 14:17:16
字體:
來源:轉載
供稿:網友

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

React 中的元素、組件、實例和節點,是React中關系密切的4個概念,也是很容易讓React 初學者迷惑的4個概念?,F在,老干部就來詳細地介紹這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 節點有一定使用場景,但看過本文后應該也就不存在理解問題了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美电影在线观看完整版| 国产一区二区美女视频| 性色av一区二区三区在线观看| 亚洲第一网站免费视频| 国产成人精品在线视频| 日韩中文有码在线视频| 伊人av综合网| 91大神福利视频在线| 久久精品在线视频| 中文字幕精品在线视频| 最近中文字幕日韩精品| 亚洲欧美激情四射在线日| 欧美一级在线亚洲天堂| 91精品国产91久久久| 成人有码在线视频| 国产97免费视| 成人免费在线网址| 亚洲精品福利在线观看| 亚洲美女www午夜| 国产日本欧美一区二区三区在线| 欧美另类极品videosbestfree| 亚洲精品资源在线| 日韩免费在线看| 91大神在线播放精品| 国产精品亚洲精品| 日韩黄在线观看| 国产视频在线观看一区二区| 国产一区二区在线免费| 亚洲欧洲在线看| 在线观看精品国产视频| 亚洲第一精品久久忘忧草社区| 爽爽爽爽爽爽爽成人免费观看| 欧美日韩成人免费| 欧美孕妇孕交黑巨大网站| 亚洲一区二区三区四区视频| 精品久久久久久亚洲精品| 亚洲精品999| 91伊人影院在线播放| 亚洲电影免费观看高清完整版| 欧美日韩中文字幕综合视频| 日本亚洲欧洲色α| 亚洲精品久久久久国产| 91欧美精品成人综合在线观看| 国产日韩在线亚洲字幕中文| 亚洲国产小视频| 亚洲欧美国产视频| 97国产suv精品一区二区62| 最近2019年日本中文免费字幕| 日韩精品一区二区视频| 91国内产香蕉| 一区二区欧美在线| 欧美专区在线视频| 国产一区二区久久精品| 亚洲偷熟乱区亚洲香蕉av| 91精品视频播放| 色综合91久久精品中文字幕| 国产日产欧美a一级在线| 一个人看的www欧美| 久久97精品久久久久久久不卡| 国产精品日韩在线| 欧美亚洲另类在线| 国产精品久久久久久久久久久新郎| 国产一区二区三区直播精品电影| 日韩免费看的电影电视剧大全| 日韩av在线影视| 91在线看www| 国产精品日韩欧美大师| 欧美黄色三级网站| 26uuu国产精品视频| 97超碰国产精品女人人人爽| 欧美黑人国产人伦爽爽爽| 欧美日韩国产麻豆| 国产精品一二区| 欧美日韩激情网| 久久久国产一区二区| 这里只有精品在线播放| 欧美与黑人午夜性猛交久久久| 久久天天躁狠狠躁夜夜躁| 欧美最猛性xxxxx免费| 亚洲男人天堂久| 欧美日韩中文在线| 国产成人精品一区二区在线| 中文字幕亚洲字幕| 欧美精品亚州精品| 国产狼人综合免费视频| 97不卡在线视频| 亚洲欧美国产高清va在线播| 久久精品国产99国产精品澳门| 国产一级揄自揄精品视频| 精品久久久久久亚洲国产300| 欧美成人激情图片网| 久久精品在线播放| 国产成人综合精品| 中文字幕成人精品久久不卡| 成人性教育视频在线观看| 国产丝袜一区视频在线观看| 精品丝袜一区二区三区| 国产成人在线视频| 在线精品高清中文字幕| 亚洲一区二区三区乱码aⅴ| 欧美日韩国产中字| 国产精品普通话| 久久亚洲综合国产精品99麻豆精品福利| 国产不卡av在线免费观看| 中国日韩欧美久久久久久久久| 亚洲跨种族黑人xxx| 欧美成人激情视频| 国产亚洲精品久久久| 久久久亚洲天堂| 久久久免费观看视频| 欧美激情2020午夜免费观看| 亚洲欧美日韩天堂一区二区| 日韩电影中文字幕av| 日韩福利在线播放| 国产午夜精品视频| 孩xxxx性bbbb欧美| 欧美成年人视频| 日韩一区二区三区xxxx| 91禁国产网站| 亚洲第一天堂无码专区| 最近2019中文字幕一页二页| 亚州精品天堂中文字幕| 精品国产乱码久久久久酒店| 亚洲欧洲一区二区三区在线观看| 午夜精品久久久久久久99热浪潮| 日本精品久久久| 欧美一区二区大胆人体摄影专业网站| 欧美激情视频网站| 伊人伊成久久人综合网小说| 一区二区三欧美| 亚洲欧美日韩精品久久奇米色影视| 日韩国产中文字幕| 97精品国产97久久久久久春色| 欧美在线精品免播放器视频| 97国产一区二区精品久久呦| 欧美成人全部免费| 羞羞色国产精品| 欧美小视频在线观看| 国产精品极品美女在线观看免费| 国产日韩欧美在线视频观看| 国产精品日韩精品| 国产精品igao视频| 91精品国产高清久久久久久久久| 精品久久久久久中文字幕一区奶水| 亚洲最大av网站| 精品少妇一区二区30p| 亚洲免费av片| 欧美整片在线观看| 国产精品劲爆视频| 91在线精品视频| 另类色图亚洲色图| 亚洲影院污污.| 最新亚洲国产精品| 欧美另类在线观看| 97精品国产97久久久久久免费| 国产日韩中文在线| 日韩av综合网| 狠狠色香婷婷久久亚洲精品| 97久久精品人人澡人人爽缅北| 久久精品国亚洲| 激情亚洲一区二区三区四区| 精品久久久一区| 久久国产精品首页| 日韩成人激情在线|