Heim Web-Frontend js-Tutorial Detaillierte Erläuterung der Elemente, Komponenten und Knoten in React

Detaillierte Erläuterung der Elemente, Komponenten und Knoten in React

Mar 01, 2018 am 09:05 AM
react 组件 节点

Dieser Artikel stellt Ihnen hauptsächlich die Elemente, Komponenten und Knoten in React vor und gibt Ihnen auch eine Referenz. Ich hoffe, er kann Ihnen helfen.

Elemente, Komponenten, Instanzen und Knoten in React sind vier eng verwandte Konzepte in React, und es sind auch vier Konzepte, die React-Anfänger leicht verwirren können. Jetzt werden erfahrene Kader diese vier Konzepte sowie die Verbindungen und Unterschiede zwischen ihnen im Detail vorstellen, um die Neugier von Studenten zu befriedigen, die gerne Wörter kauen und den Dingen auf den Grund gehen (zu ihnen gehören erfahrene Kader).

Element (Element)

React-Element ist eigentlich ein einfaches JavaScript-Objekt, das einem Teil des DOM auf der Schnittstelle entspricht und dessen Struktur und Struktur beschreibt dieses Teils des DOM. Im Allgemeinen erstellen wir React-Elemente über die JSX-Syntax, zum Beispiel:


const element = <h1 className=&#39;greeting&#39;>Hello, world</h1>;
Nach dem Login kopieren

Element ist ein React-Element. Während des Kompilierungsprozesses wird die JSX-Syntax in einen Aufruf von React.createElement() kompiliert. Aus dem Funktionsnamen ist auch ersichtlich, dass die JSX-Syntax ein React-Element zurückgibt. Das kompilierte Ergebnis des obigen Beispiels ist:


const element = React.createElement(
 &#39;h1&#39;,
 {className: &#39;greeting&#39;},
 &#39;Hello, world!&#39;
);
Nach dem Login kopieren

Schließlich ist der Wert von element ein einfaches JavaScript-Objekt ähnlich dem folgenden:


const element = {
 type: &#39;h1&#39;,
 props: {
  className: &#39;greeting&#39;,
  children: &#39;Hello, world&#39;
 }
}
Nach dem Login kopieren

React-Elemente können in zwei Kategorien unterteilt werden: DOM-Typelemente und Komponententypelemente. Elemente vom Typ DOM verwenden DOM-Knoten wie h1, p, p usw., um React-Elemente zu erstellen. Das vorherige Beispiel ist ein Element vom Typ DOM, das React-Komponenten zum Erstellen von React-Elementen verwendet 🎜>


buttonElement ist ein Komponententypelement, sein Wert ist:

const buttonElement = <Button color=&#39;red&#39;>OK</Button>;
Nach dem Login kopieren


Für DOM-Typelemente, weil es dasselbe ist Da die DOM-Knoten der Seite direkt korrespondieren, weiß React, wie man rendert. Bei Komponententypelementen wie buttonElement kann React jedoch nicht direkt wissen, in welche Art von Seiten-DOM das buttonElement gerendert werden soll. In diesem Fall muss die Komponente selbst DOM-Knoteninformationen bereitstellen, die React erkennen kann werden bei der Einführung der Komponente ausführlich besprochen.

const buttonElement = {
 type: &#39;Button&#39;,
 props: {
  color: &#39;red&#39;,
  children: &#39;OK&#39;
 }
}
Nach dem Login kopieren
Wie sollten wir das React-Element verwenden? Tatsächlich werden wir in den meisten Fällen React-Elemente nicht direkt verwenden. React rendert das endgültige Seiten-DOM automatisch basierend auf den React-Elementen. Genauer gesagt beschreiben React-Elemente die Struktur des virtuellen DOM von React, und React rendert das reale DOM der Seite basierend auf dem virtuellen DOM.

Komponente (Komponente)

React-Komponente sollte das bekannteste Konzept in React sein. React nutzt die Idee der Komponenten, um die Schnittstelle in wiederverwendbare Module aufzuteilen. Jedes Modul ist eine React-Komponente. Eine React-Anwendung besteht aus mehreren Komponenten, und eine komplexe Komponente kann auch aus mehreren einfachen Komponenten bestehen.

React-Komponenten sind eng mit React-Elementen verbunden. Die Kernfunktion von React-Komponenten besteht darin, React-Elemente zurückzugeben. Möglicherweise haben Sie hier Fragen: Sollten React-Elemente nicht von React.createElement() zurückgegeben werden? Aber auch der Aufruf von React.createElement() selbst erfordert, dass eine „Person“ verantwortlich ist, und die React-Komponente ist diese „verantwortliche Person“. Die React-Komponente ist dafür verantwortlich, React.createElement() aufzurufen und das React-Element zurückzugeben, damit React es intern im endgültigen Seiten-DOM rendert.

Da die Kernfunktion einer Komponente darin besteht, React-Elemente zurückzugeben, ist die einfachste Komponente eine Funktion, die React-Elemente zurückgibt:


Willkommen ist a Mit Funktionen definierte Komponenten. Wenn eine Komponente mithilfe einer Klasse definiert wird, wird die Rückgabe des React-Elements speziell von der Rendermethode der Komponente übernommen, zum Beispiel:

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


Tatsächlich Bei mithilfe von Klassen definierten Komponenten ist die Render-Methode die einzige erforderliche Methode. Die Lebenszyklusmethoden anderer Komponenten dienen nur dem Rendern und sind nicht erforderlich.

class Welcome extends React.Component {
 render() {
  return <h1>Hello, {this.props.name}</h1>;
 }
}
Nach dem Login kopieren
Betrachten Sie nun das folgende Beispiel:


Home-Komponente verwendet die Welcome-Komponente und das zurückgegebene React-Element ist:

class Home extends React.Component {
 render() {
  return (
   <p>
    <Welcome name=&#39;老干部&#39; />
    <p>Anything you like</p>
   </p>
  )
 }
}
Nach dem Login kopieren


Für diese Struktur weiß React, wie Knoten mit Typ = 'p' und Typ = 'p' gerendert werden, weiß jedoch nicht, wie Knoten mit Typ = 'Welcome' gerendert werden. Wenn React feststellt, dass Welcome eine React-Komponente ist (die Beurteilung basiert auf der Tatsache, dass der erste Buchstabe von Welcome großgeschrieben wird), wird die Art und Weise, wie der Welcome-Knoten gerendert wird, anhand des von der Welcome-Komponente zurückgegebenen React-Elements bestimmt. Die von der Welcome-Komponente zurückgegebenen React-Elemente sind:

{
 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;
    }
   },
  ]
 }
}
Nach dem Login kopieren


Diese Struktur enthält nur DOM-Knoten und React weiß, wie man rendert. Wenn diese Struktur auch andere Komponentenknoten enthält, wiederholt React den obigen Vorgang und analysiert die von den entsprechenden Komponenten zurückgegebenen React-Elemente weiter, bis die zurückgegebenen React-Elemente nur noch DOM-Knoten enthalten. Dieser rekursive Prozess ermöglicht es React, die vollständigen DOM-Strukturinformationen der Seite abzurufen, und die Rendering-Arbeit erfolgt auf natürliche Weise.

{
 type: &#39;h1&#39;,
 props: {
  children: &#39;Hello, 老干部&#39;
 }
}
Nach dem Login kopieren
Wenn Sie darüber hinaus sorgfältig darüber nachdenken, können Sie feststellen, dass die Wiederverwendung von React-Komponenten im Wesentlichen darin besteht, die von dieser Komponente zurückgegebenen React-Elemente wiederzuverwenden.

Instanz

这里的实例特指React组件的实例。React 组件是一个函数或类,实际工作时,发挥作用的是React 组件的实例对象。只有组件实例化后,每一个组件实例才有了自己的props和state,才持有对它的DOM节点和子组件实例的引用。在传统的面向对象的开发方式中,实例化的工作是由开发者自己手动完成的,但在React中,组件的实例化工作是由React自动完成的,组件实例也是直接由React管理的。换句话说,开发者完全不必关心组件实例的创建、更新和销毁。

节点 (Node)

在使用PropTypes校验组件属性时,有这样一种类型:


MyComponent.propTypes = { 
 optionalNode: PropTypes.node,
}
Nach dem Login kopieren

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;
}
Nach dem Login kopieren

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

相关推荐:

React中组件间抽象实例讲解

React中组件的写法有哪些

简单搭建一个react项目

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Elemente, Komponenten und Knoten in React. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket So erstellen Sie eine Echtzeit-Chat-App mit React und WebSocket Sep 26, 2023 pm 07:46 PM

So erstellen Sie eine Echtzeit-Chat-Anwendung mit React und WebSocket Einführung: Mit der rasanten Entwicklung des Internets hat die Echtzeitkommunikation immer mehr Aufmerksamkeit auf sich gezogen. Live-Chat-Apps sind aus dem modernen Sozial- und Arbeitsleben nicht mehr wegzudenken. In diesem Artikel wird erläutert, wie Sie mit React und WebSocket eine einfache Echtzeit-Chat-Anwendung erstellen, und es werden spezifische Codebeispiele bereitgestellt. 1. Technische Vorbereitung Bevor wir mit der Erstellung einer Echtzeit-Chat-Anwendung beginnen, müssen wir die folgenden Technologien und Tools vorbereiten: React: eine zum Erstellen

Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Leitfaden zur React-Front-End- und Back-End-Trennung: So erreichen Sie die Entkopplung und unabhängige Bereitstellung von Front-End und Back-End Sep 28, 2023 am 10:48 AM

React-Leitfaden zur Front-End- und Back-End-Trennung: So erreichen Sie die Front-End- und Back-End-Entkopplung und die unabhängige Bereitstellung. Es sind spezifische Codebeispiele erforderlich. In der heutigen Webentwicklungsumgebung ist die Front-End- und Back-End-Trennung zu einem Trend geworden. Durch die Trennung von Front-End- und Back-End-Code kann die Entwicklungsarbeit flexibler und effizienter gestaltet und die Zusammenarbeit im Team erleichtert werden. In diesem Artikel wird erläutert, wie Sie mithilfe von React eine Front-End- und Back-End-Trennung erreichen und so die Ziele der Entkopplung und unabhängigen Bereitstellung erreichen. Zuerst müssen wir verstehen, was Front-End- und Back-End-Trennung ist. Im traditionellen Webentwicklungsmodell sind Front-End und Back-End gekoppelt

So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask So erstellen Sie einfache und benutzerfreundliche Webanwendungen mit React und Flask Sep 27, 2023 am 11:09 AM

So erstellen Sie mit React und Flask einfache und benutzerfreundliche Webanwendungen. Einführung: Mit der Entwicklung des Internets werden die Anforderungen an Webanwendungen immer vielfältiger und komplexer. Um den Anforderungen der Benutzer an Benutzerfreundlichkeit und Leistung gerecht zu werden, wird es immer wichtiger, moderne Technologie-Stacks zum Aufbau von Netzwerkanwendungen zu verwenden. React und Flask sind zwei sehr beliebte Frameworks für die Front-End- und Back-End-Entwicklung, und sie arbeiten gut zusammen, um einfache und benutzerfreundliche Webanwendungen zu erstellen. In diesem Artikel erfahren Sie, wie Sie React und Flask nutzen

So installieren Sie die DirectPlay-Komponente der alten Windows 10-Version So installieren Sie die DirectPlay-Komponente der alten Windows 10-Version Dec 28, 2023 pm 03:43 PM

Viele Benutzer stoßen beim Spielen einiger Spiele unter Win10 immer auf Probleme, wie z. B. ein Einfrieren des Bildschirms und unscharfe Bildschirme. Zu diesem Zeitpunkt können wir das Problem lösen, indem wir die Directplay-Funktion aktivieren, und die Bedienungsmethode der Funktion ist ebenfalls sehr einfach. So installieren Sie DirectPlay, die alte Komponente von Win10 1. Geben Sie „Systemsteuerung“ in das Suchfeld ein und öffnen Sie es. 2. Wählen Sie große Symbole als Anzeigemethode. 3. Suchen Sie nach „Programme und Funktionen“. 4. Klicken Sie links, um oder zu aktivieren Win-Funktionen ausschalten 5. Wählen Sie hier die alte Version aus. Aktivieren Sie einfach das Kontrollkästchen

So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ So erstellen Sie eine zuverlässige Messaging-App mit React und RabbitMQ Sep 28, 2023 pm 08:24 PM

So erstellen Sie eine zuverlässige Messaging-Anwendung mit React und RabbitMQ Einführung: Moderne Anwendungen müssen zuverlässiges Messaging unterstützen, um Funktionen wie Echtzeitaktualisierungen und Datensynchronisierung zu erreichen. React ist eine beliebte JavaScript-Bibliothek zum Erstellen von Benutzeroberflächen, während RabbitMQ eine zuverlässige Messaging-Middleware ist. In diesem Artikel wird erläutert, wie Sie React und RabbitMQ kombinieren, um eine zuverlässige Messaging-Anwendung zu erstellen, und es werden spezifische Codebeispiele bereitgestellt. RabbitMQ-Übersicht:

React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung React Router-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Sep 29, 2023 pm 05:45 PM

ReactRouter-Benutzerhandbuch: So implementieren Sie die Front-End-Routing-Steuerung Mit der Popularität von Single-Page-Anwendungen ist das Front-End-Routing zu einem wichtigen Bestandteil geworden, der nicht ignoriert werden kann. Als beliebteste Routing-Bibliothek im React-Ökosystem bietet ReactRouter umfangreiche Funktionen und benutzerfreundliche APIs, wodurch die Implementierung des Front-End-Routings sehr einfach und flexibel ist. In diesem Artikel wird die Verwendung von ReactRouter vorgestellt und einige spezifische Codebeispiele bereitgestellt. Um ReactRouter zuerst zu installieren, benötigen wir

So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery So erstellen Sie eine schnelle Datenanalyseanwendung mit React und Google BigQuery Sep 26, 2023 pm 06:12 PM

So verwenden Sie React und Google BigQuery zum Erstellen schneller Datenanalyseanwendungen. Einführung: Im heutigen Zeitalter der Informationsexplosion ist die Datenanalyse zu einem unverzichtbaren Bindeglied in verschiedenen Branchen geworden. Unter anderem ist die Entwicklung schneller und effizienter Datenanalyseanwendungen für viele Unternehmen und Einzelpersonen zum Ziel geworden. In diesem Artikel wird erläutert, wie Sie mit React und Google BigQuery eine schnelle Datenanalyseanwendung erstellen, und es werden detaillierte Codebeispiele bereitgestellt. 1. Übersicht React ist ein Werkzeug zum Erstellen

So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka So erstellen Sie Echtzeit-Datenverarbeitungsanwendungen mit React und Apache Kafka Sep 27, 2023 pm 02:25 PM

So verwenden Sie React und Apache Kafka zum Erstellen von Echtzeit-Datenverarbeitungsanwendungen. Einführung: Mit dem Aufkommen von Big Data und Echtzeit-Datenverarbeitung ist die Erstellung von Echtzeit-Datenverarbeitungsanwendungen für viele Entwickler zum Ziel geworden. Die Kombination von React, einem beliebten Front-End-Framework, und Apache Kafka, einem leistungsstarken verteilten Messaging-System, kann uns beim Aufbau von Echtzeit-Datenverarbeitungsanwendungen helfen. In diesem Artikel wird erläutert, wie Sie mit React und Apache Kafka Echtzeit-Datenverarbeitungsanwendungen erstellen

See all articles