首頁 web前端 js教程 react中元素和元件的差別是什麼

react中元素和元件的差別是什麼

Nov 17, 2020 pm 02:47 PM
react

react中元素和組件的區別:1、元素資料結構是普通對象,而組件資料結構是類別或純函數;2、在JSX中,被元素嵌套的元素會以屬性children的方式傳入該元素的組件。

react中元素和元件的差別是什麼

react中元素與元件的差異:

##1、React 元素

React 元素(React element),它是React 中最小基本單位,我們可以使用JSX 語法輕鬆地創建一個React 元素:

const element = <div className="element">I&#39;m element</div>
登入後複製

React 元素不是真實的DOM 元素,它只是js的普通物件(plain objects),所以也沒辦法直接呼叫DOM 原生的API。上面的 JSX 轉譯後的物件大概是這樣的:

{
    _context: Object,
    _owner: null,
    key: null,
    props: {
    className: &#39;element&#39;,
    children: &#39;I&#39;m element&#39;
  },
    ref: null,
    type: "div"
}
登入後複製

只有在這個元素渲染完成後,才能透過選擇器的方式取得它對應的 DOM 元素。不過,依照React 有限狀態機的設計思想,應該使用狀態和屬性來表述元件,要盡量避免DOM 操作,即便要進行DOM 操作,也應該使用React 提供的介面ref和

getDOMNode() 。一般使用 React 提供的介面就足以應付需要 DOM 操作的場景了,因此像 jQuery 強大的選擇器在 React 中幾乎沒有用武之地了。

除了使用 JSX 語法,我們還可以使用

React.createElement()React.cloneElement() 來建立 React 元素。

React.createElement()

JSX 語法就是用

React.createElement()來建構 React 元素的。它接受三個參數,第一個參數可以是一個標籤名。如div、span,或 React 元件。第二個參數為傳入的屬性。第三個以及之後的參數,皆作為組件的子組件。

React.createElement(
    type,
    [props],
    [...children]
)
登入後複製

React.cloneElement()

React.cloneElement()與React.createElement()相似,不同的是它傳入的第一個參數是一個React 元素,而不是標籤名或元件。新加入的屬性會併入原有的屬性,傳入到傳回的新元素中,而就的子元素獎盃替換。

React.cloneElement(
  element,
  [props],
  [...children]
)
登入後複製

2、React 元件

React 中有三種建構元件的方式。 React.createClass()、ES6 class和無狀態函數。

React.createClass()

React.createClass()是三種方式中最早,相容性最好的方法。在0.14版本前官方指定的組件寫法。

var Greeting = React.createClass({
  render: function() {
    return <h1>Hello, {this.props.name}</h1>;
  }
});
登入後複製

ES6 class

ES6 class是目前官方推薦的使用方式,它使用了ES6標準語法來構建,但它的實作仍是呼叫

React.createClass()來實現了,ES6 class的生命週期和自動綁定方式與React.createClass()略有不同。

class Greeting extemds React.Component{
  render: function() {
    return <h1>Hello, {this.props.name}</h1>;
  }
};
登入後複製

無狀態函數

無狀態函數是使用函數建構的無狀態元件,無狀態元件傳入props和context兩個參數,它沒有state,除了render(),沒有其它生命週期方法。

function Greeting (props) {
  return <h1>Hello, {props.name}</h1>;
}
登入後複製

React.createClass()和ES6 class建構的元件的資料結構是類,無狀態元件資料結構是函數,它們在 React 被視為是一樣的。

3、元素與元件的差異

元件是由元素構成的。元素資料結構是普通對象,而元件資料結構是類別或純函數。除此之外,還有幾點差異要注意:

this.props.children

在JSX 中,被元素嵌套的元素會以屬性children的方式傳入該元素的組件。當僅嵌套一個元素時,children 是一個 React 元素,當嵌套多個元素時,children 是一個 React 元素的陣列。可以直接把 children 寫入 JSX 的中,但如果要給它們傳入新屬性,就要用到

React.cloneElement()來建立新的元素。我曾經放過以下錯誤:

render () {
  var Child = this.props.children
  return <div><Child tip={&#39;error!&#39;}/><div>
}
登入後複製

因為Child 是一個React 元素,而不是元件,這樣的寫法是完全錯誤的,正確的方式應該是:

render () {
  var child = this.props.children
  return <div>{ React.cloneElement(child, {tip: &#39;right way!&#39;}) }<div>
}
登入後複製

就這樣,原有屬性和新加入的屬性被一併傳入了子元素。使用React.cloneElement()才是操作元素的正確姿勢。

使用者元件

有的時候,元件可以讓使用者以屬性的方式傳入自訂的元件,來提升元件的彈性。這個屬性傳入的就應該是 React 元素,而非 React 元件。使用 React 元素可以讓使用者傳入自訂元件的同時,為元件新增屬性。同樣,可以使用React.cloneElement()為自訂元件添加更多屬性,或取代子元素。

// 推荐
<MyComponent tick={
  <UserComponent tip="Yes"/>
} />
 
// 不推荐
<MyComponent tick={ UserComponent } />
登入後複製

最後

最後,打個不恰當的比喻,React 元件是MyComponent,React 元素就是

相關免費學習推薦:JavaScript(影片)

######

以上是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)

如何利用React和WebSocket建立即時聊天應用 如何利用React和WebSocket建立即時聊天應用 Sep 26, 2023 pm 07:46 PM

如何利用React和WebSocket建立即時聊天應用程式引言:隨著網路的快速發展,即時通訊越來越受到人們的關注。即時聊天應用程式已成為現代社交和工作生活中不可或缺的一部分。本文將介紹如何利用React和WebSocket建立一個簡單的即時聊天應用,並提供具體的程式碼範例。一、技術準備在開始建立即時聊天應用之前,我們需要準備以下技術和工具:React:一個用於構建

React前後端分離指南:如何實作前後端的解耦與獨立部署 React前後端分離指南:如何實作前後端的解耦與獨立部署 Sep 28, 2023 am 10:48 AM

React前後端分離指南:如何實現前後端的解耦和獨立部署,需要具體程式碼範例在當今的Web開發環境中,前後端分離已經成為一種趨勢。透過將前端和後端程式碼分開,可以讓開發工作更加靈活、高效,並且方便進行團隊協作。本文將介紹如何使用React實現前後端分離,從而實現解耦和獨立部署的目標。首先,我們要先理解什麼是前後端分離。傳統的Web開發模式中,前端和後端是耦合在

如何利用React和Flask建構簡單易用的網路應用 如何利用React和Flask建構簡單易用的網路應用 Sep 27, 2023 am 11:09 AM

如何利用React和Flask建構簡單易用的網路應用引言:隨著網路的發展,網路應用的需求也越來越多樣化和複雜化。為了滿足使用者對於易用性和效能的要求,使用現代化的技術堆疊來建立網路應用變得越來越重要。 React和Flask是兩個在前端和後端開發中非常受歡迎的框架,它們可以很好的結合在一起,用來建立簡單易用的網路應用。本文將詳細介紹如何利用React和Flask

如何利用React和RabbitMQ建立可靠的訊息應用 如何利用React和RabbitMQ建立可靠的訊息應用 Sep 28, 2023 pm 08:24 PM

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

React Router使用指南:如何實現前端路由控制 React Router使用指南:如何實現前端路由控制 Sep 29, 2023 pm 05:45 PM

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

如何利用React和Google BigQuery建立快速的資料分析應用 如何利用React和Google BigQuery建立快速的資料分析應用 Sep 26, 2023 pm 06:12 PM

如何利用React和GoogleBigQuery建立快速的資料分析應用引言:在當今資訊爆炸的時代,資料分析已經成為了各產業中不可或缺的環節。而其中,建構快速、有效率的資料分析應用則成為了許多企業和個人追求的目標。本文將介紹如何利用React和GoogleBigQuery結合來建立快速的資料分析應用,並提供詳細的程式碼範例。一、概述React是用來構建

如何利用React和Docker打包部署前端應用 如何利用React和Docker打包部署前端應用 Sep 26, 2023 pm 03:14 PM

如何利用React和Docker打包和部署前端應用前端應用的打包和部署是專案開發中非常重要的一環。隨著現代前端框架的快速發展,React成為了許多前端開發人員的首選。而Docker作為一種容器化解決方案,可以大幅簡化應用的部署過程。本文將介紹如何利用React和Docker打包和部署前端應用,並提供具體的程式碼範例。一、準備工作在開始前,我們需要先安裝

如何利用React與Apache Kafka建構即時資料處理應用 如何利用React與Apache Kafka建構即時資料處理應用 Sep 27, 2023 pm 02:25 PM

如何利用React和ApacheKafka來建立即時資料處理應用介紹:隨著大數據與即時資料處理的興起,建構即時資料處理應用成為了許多開發者的追求。 React作為一個流行的前端框架,與ApacheKafka作為一個高效能的分散式訊息系統的結合,可以幫助我們建立即時資料處理應用。本文將介紹如何利用React和ApacheKafka建構即時資料處理應用,並

See all articles