首頁 web前端 js教程 詳細解讀React中的元素、元件、實例和節點

詳細解讀React中的元素、元件、實例和節點

Jun 04, 2018 am 10:56 AM
react 元素

這篇文章主要介紹了淺談React中的元素、元件、實例和節點,現在分享給大家,也為大家做個參考。

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

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

元素(Element)

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

const element = <h1 className=&#39;greeting&#39;>Hello, world</h1>;
登入後複製

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

const element = React.createElement(
 &#39;h1&#39;,
 {className: &#39;greeting&#39;},
 &#39;Hello, world!&#39;
);
登入後複製

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

const element = {
 type: &#39;h1&#39;,
 props: {
  className: &#39;greeting&#39;,
  children: &#39;Hello, world&#39;
 }
}
登入後複製

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

const buttonElement = <Button color=&#39;red&#39;>OK</Button>;
登入後複製

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

const buttonElement = {
 type: &#39;Button&#39;,
 props: {
  color: &#39;red&#39;,
  children: &#39;OK&#39;
 }
}
登入後複製

對於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 (
   <p>
    <Welcome name=&#39;老干部&#39; />
    <p>Anything you like</p>
   </p>
  )
 }
}
登入後複製

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

{
 type: &#39;p&#39;,
 props: {
  children: [
   {
    type: &#39;Welcome&#39;,
    props: {
     name: &#39;老干部&#39;
    }
   },
   {
    type: &#39;p&#39;,
    props: {
     children: &#39;Anything you like&#39;
    }
   },
  ]
 }
}
登入後複製

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

{
 type: &#39;h1&#39;,
 props: {
  children: &#39;Hello, 老干部&#39;
 }
}
登入後複製

這個結構只包含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 &#39;MyComponent&#39;;
}

// React元素类型的节点
function MyComponent(props) {
 return <p>React Element</p>;
}

// 数组类型的节点,数组的元素只能是其他合法的React节点
function MyComponent(props) {
 const element = <p>React Element</p>;
 const arr = [1, &#39;MyComponent&#39;, element];
 return arr;
}

// 错误,不是合法的React节点
function MyComponent(props) {
 const obj = { a : 1}
 return obj;
}
登入後複製

最后总结一下,React 元素和组件的概念最重要,也最容易混淆;React 组件实例的概念大家了解即可,几乎使用不到;React 节点有一定使用场景,但看过本文后应该也就不存在理解问题了。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

通过JS中利用FileReader如何实现上传图片前本地预览功能

根据select标签设置默认选中的选项方法该怎么做?

原生JavaScript中如何实现todolist功能

以上是詳細解讀React中的元素、元件、實例和節點的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP、Vue和React:如何選擇最適合的前端框架? PHP、Vue和React:如何選擇最適合的前端框架? Mar 15, 2024 pm 05:48 PM

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

Java框架與前端React框架的整合 Java框架與前端React框架的整合 Jun 01, 2024 pm 03:16 PM

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

vue.js vs.反應:特定於項目的考慮因素 vue.js vs.反應:特定於項目的考慮因素 Apr 09, 2025 am 12:01 AM

Vue.js適合中小型項目和快速迭代,React適用於大型複雜應用。 1)Vue.js易於上手,適用於團隊經驗不足或項目規模較小的情況。 2)React的生態系統更豐富,適合有高性能需求和復雜功能需求的項目。

React在HTML中的作用:增強用戶體驗 React在HTML中的作用:增強用戶體驗 Apr 09, 2025 am 12:11 AM

React通過JSX與HTML結合,提升用戶體驗。 1)JSX嵌入HTML,使開發更直觀。 2)虛擬DOM機制優化性能,減少DOM操作。 3)組件化管理UI,提高可維護性。 4)狀態管理和事件處理增強交互性。

jQuery中如何檢查元素是否包含某個屬性值? jQuery中如何檢查元素是否包含某個屬性值? Feb 28, 2024 pm 02:54 PM

在jQuery中,我們經常需要檢查元素是否包含特定的屬性值。這樣做可以幫助我們根據元素上的屬性值執行對應的操作。在本文中,我將介紹如何使用jQuery來檢查元素是否包含某個屬性值,並提供具體的程式碼範例。首先,讓我們先了解jQuery中的一些常用方法來操作元素的屬性:.attr():用來取得或設定元素的屬性值。 .prop():用於取得或設定元素的屬性值

實作動態新增元素到div的jQuery方法 實作動態新增元素到div的jQuery方法 Feb 24, 2024 pm 08:03 PM

jQuery是一個流行的JavaScript函式庫,用來簡化JavaScript程式設計。它提供了豐富的功能和方法,包括在HTML元素中動態新增元素的功能。本文將介紹如何使用jQuery來動態新增元素,同時提供具體的程式碼範例。首先,我們需要在HTML文件中引入jQuery函式庫。可以透過以下方式引入:

使用jQuery判斷元素的顯示狀態 使用jQuery判斷元素的顯示狀態 Feb 23, 2024 pm 09:24 PM

用jQuery實作元素的可見不可見判斷在網頁開發中,常常會遇到需要判斷某個元素是否可見的情況。透過jQuery可以很方便地實現對元素可見性的判斷和操作。本文將介紹如何使用jQuery來實現對元素可見性的判斷,同時提供具體的程式碼範例。 jQuery的元素可見性判斷方法在jQuery中,可以利用一些特定的方法來判斷元素的可見性。其中最常用的方法是.is(':vis

反應與前端:建立互動體驗 反應與前端:建立互動體驗 Apr 11, 2025 am 12:02 AM

React是構建交互式前端體驗的首選工具。 1)React通過組件化和虛擬DOM簡化UI開發。 2)組件分為函數組件和類組件,函數組件更簡潔,類組件提供更多生命週期方法。 3)React的工作原理依賴虛擬DOM和調和算法,提高性能。 4)狀態管理使用useState或this.state,生命週期方法如componentDidMount用於特定邏輯。 5)基本用法包括創建組件和管理狀態,高級用法涉及自定義鉤子和性能優化。 6)常見錯誤包括狀態更新不當和性能問題,調試技巧包括使用ReactDevTools和優

See all articles