Maison interface Web js tutoriel Explication détaillée des éléments, composants et nœuds dans React

Explication détaillée des éléments, composants et nœuds dans React

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

Cet article vous présente principalement les éléments, composants et nœuds de React, et vous donne également une référence. J'espère qu'il pourra vous aider.

Les éléments, composants, instances et nœuds dans React sont quatre concepts étroitement liés dans React, et ce sont également quatre concepts qui peuvent facilement dérouter les débutants de React. Les cadres vétérans présenteront désormais en détail ces quatre concepts, ainsi que les liens et les différences entre eux, pour satisfaire la curiosité des étudiants qui aiment mâcher des mots et aller au fond des choses (les cadres vétérans en font partie).

Element (Element)

L'élément React est en fait un simple objet JavaScript. Un élément React correspond à une partie du DOM sur l'interface, décrivant la structure et la structure. de cette partie du DOM. Généralement, nous créons des éléments React via la syntaxe JSX, par exemple :


const element = <h1 className=&#39;greeting&#39;>Hello, world</h1>;
Copier après la connexion

l'élément est un élément React. Pendant le processus de compilation, la syntaxe JSX sera compilée dans un appel à React.createElement(). Le nom de la fonction montre également que la syntaxe JSX renvoie un élément React. Le résultat compilé de l'exemple ci-dessus est :


const element = React.createElement(
 &#39;h1&#39;,
 {className: &#39;greeting&#39;},
 &#39;Hello, world!&#39;
);
Copier après la connexion

Enfin, la valeur de l'élément est un simple objet JavaScript similaire au suivant :


const element = {
 type: &#39;h1&#39;,
 props: {
  className: &#39;greeting&#39;,
  children: &#39;Hello, world&#39;
 }
}
Copier après la connexion

Les éléments React peuvent être divisés en deux catégories : les éléments de type DOM et les éléments de type composant. Les éléments de type DOM utilisent des nœuds DOM comme h1, p, p, etc. pour créer des éléments React. L'exemple précédent est un élément de type DOM ; les éléments de type composant utilisent des composants React pour créer des éléments React, par exemple :


const buttonElement = <Button color=&#39;red&#39;>OK</Button>;
Copier après la connexion

buttonElement est un élément de type composant, sa valeur est :


const buttonElement = {
 type: &#39;Button&#39;,
 props: {
  color: &#39;red&#39;,
  children: &#39;OK&#39;
 }
}
Copier après la connexion

Pour les éléments de type DOM, car c'est le même comme les nœuds DOM de la page correspondent directement, React sait comment effectuer le rendu. Cependant, pour les éléments de type composant, tels que ButtonElement, React ne peut pas savoir directement dans quel type de page DOM le ButtonElement doit être rendu. Dans ce cas, le composant lui-même doit fournir des informations sur le nœud DOM que React peut reconnaître. être discuté lors de l’introduction du composant.

Avec l'élément React, comment doit-on l'utiliser ? En fait, dans la plupart des cas, nous n'utiliserons pas directement les éléments React. React restituera automatiquement la page finale DOM basée sur les éléments React en interne. Pour être plus précis, les éléments React décrivent la structure du DOM virtuel de React, et React restituera le vrai DOM de la page basé sur le DOM virtuel.

Composant (Composant)

Le composant React devrait être le concept le plus familier dans React. React utilise l'idée de composants pour diviser l'interface en modules réutilisables. Chaque module est un composant React. Une application React est composée de plusieurs composants, et un composant complexe peut également être composé de plusieurs composants simples.

Les composants React sont étroitement liés aux éléments React. La fonction principale des composants React est de renvoyer des éléments React. Vous avez peut-être des questions ici : les éléments React ne devraient-ils pas être renvoyés par React.createElement() ? Mais l'appel lui-même de React.createElement() doit également avoir une « personne » responsable, et le composant React est cette « personne responsable ». Le composant React est chargé d'appeler React.createElement() et de renvoyer l'élément React pour que React le restitue en interne dans la page DOM finale.

Puisque la fonction principale d'un composant est de renvoyer des éléments React, le composant le plus simple est une fonction qui renvoie des éléments React :


function Welcome(props) {
 return <h1>Hello, {props.name}</h1>;
}
Copier après la connexion

Bienvenue est a Composants définis avec des fonctions. Si un composant est défini à l'aide d'une classe, le travail de renvoi de l'élément React est supporté par la méthode de rendu du composant, par exemple :


class Welcome extends React.Component {
 render() {
  return <h1>Hello, {this.props.name}</h1>;
 }
}
Copier après la connexion

En fait, composants définis à l’aide de classes , la méthode render est la seule méthode requise. Les méthodes de cycle de vie des autres composants sont uniquement destinées au rendu et ne sont pas obligatoires.

Considérons maintenant l'exemple suivant :


class Home extends React.Component {
 render() {
  return (
   <p>
    <Welcome name=&#39;老干部&#39; />
    <p>Anything you like</p>
   </p>
  )
 }
}
Copier après la connexion

Le composant Home utilise le composant Welcome et l'élément React renvoyé est :


{
 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;
    }
   },
  ]
 }
}
Copier après la connexion

Pour cette structure, React sait comment restituer les nœuds avec type = 'p' et type = 'p', mais ne sait pas comment restituer les nœuds avec type = 'Welcome'. Lorsque React trouve Lorsque Welcome est un composant React (le jugement est basé sur le fait que la première lettre de Welcome est en majuscule), la façon de restituer le nœud Welcome sera déterminée en fonction de l'élément React renvoyé par le composant Welcome. Les éléments React renvoyés par le composant Welcome sont :


{
 type: &#39;h1&#39;,
 props: {
  children: &#39;Hello, 老干部&#39;
 }
}
Copier après la connexion

Cette structure ne contient que des nœuds DOM, et React sait comment effectuer le rendu. Si cette structure contient également d'autres nœuds de composants, React répétera le processus ci-dessus et continuera à analyser les éléments React renvoyés par les composants correspondants jusqu'à ce que les éléments React renvoyés ne contiennent que des nœuds DOM. Ce processus récursif permet à React d'obtenir les informations complètes sur la structure DOM de la page, et le travail de rendu vient naturellement.

De plus, si vous y réfléchissez bien, vous constaterez que la réutilisation des composants React consiste essentiellement à réutiliser les éléments React renvoyés par ce composant. Les éléments React sont l'unité la plus basique des applications React.

Instance

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

节点 (Node)

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


MyComponent.propTypes = { 
 optionalNode: PropTypes.node,
}
Copier après la connexion

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;
}
Copier après la connexion

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

相关推荐:

React中组件间抽象实例讲解

React中组件的写法有哪些

简单搭建一个react项目

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide pour la séparation du front-end et du back-end de React : Comment réaliser le découplage et le déploiement indépendant du front-end et du back-end Guide pour la séparation du front-end et du back-end de React : Comment réaliser le découplage et le déploiement indépendant du front-end et du back-end Sep 28, 2023 am 10:48 AM

Guide de séparation front-end et back-end de React : Comment réaliser un découplage front-end et back-end et un déploiement indépendant, des exemples de code spécifiques sont nécessaires Dans l'environnement de développement Web actuel, la séparation front-end et back-end est devenue une tendance. En séparant le code front-end et back-end, le travail de développement peut être rendu plus flexible, plus efficace et faciliter la collaboration en équipe. Cet article expliquera comment utiliser React pour réaliser une séparation front-end et back-end, atteignant ainsi les objectifs de découplage et de déploiement indépendant. Tout d’abord, nous devons comprendre ce qu’est la séparation front-end et back-end. Dans le modèle de développement Web traditionnel, le front-end et le back-end sont couplés

Comment installer le composant DirectPlay de l'ancienne version de Windows 10 Comment installer le composant DirectPlay de l'ancienne version de Windows 10 Dec 28, 2023 pm 03:43 PM

De nombreux utilisateurs rencontrent toujours des problèmes lorsqu'ils jouent à certains jeux sur Win10, tels que le gel de l'écran et les écrans flous. À l'heure actuelle, nous pouvons résoudre le problème en activant la fonction de lecture directe, et la méthode de fonctionnement de la fonction est également très simple. Comment installer Directplay, l'ancien composant de Win10 1. Entrez "Panneau de configuration" dans la zone de recherche et ouvrez-le 2. Sélectionnez de grandes icônes comme méthode d'affichage 3. Recherchez "Programmes et fonctionnalités" 4. Cliquez sur la gauche pour activer ou désactiver les fonctions Win 5. Sélectionnez l'ancienne version ici Cochez simplement la case

Comment créer une application de messagerie fiable avec React et RabbitMQ Comment créer une application de messagerie fiable avec React et RabbitMQ Sep 28, 2023 pm 08:24 PM

Comment créer une application de messagerie fiable avec React et RabbitMQ Introduction : Les applications modernes doivent prendre en charge une messagerie fiable pour obtenir des fonctionnalités telles que les mises à jour en temps réel et la synchronisation des données. React est une bibliothèque JavaScript populaire pour créer des interfaces utilisateur, tandis que RabbitMQ est un middleware de messagerie fiable. Cet article explique comment combiner React et RabbitMQ pour créer une application de messagerie fiable et fournit des exemples de code spécifiques. Présentation de RabbitMQ :

Guide de l'utilisateur de React Router : Comment implémenter le contrôle de routage frontal Guide de l'utilisateur de React Router : Comment implémenter le contrôle de routage frontal Sep 29, 2023 pm 05:45 PM

Guide de l'utilisateur de ReactRouter : Comment implémenter le contrôle du routage frontal Avec la popularité des applications monopage, le routage frontal est devenu un élément important qui ne peut être ignoré. En tant que bibliothèque de routage la plus populaire de l'écosystème React, ReactRouter fournit des fonctions riches et des API faciles à utiliser, rendant la mise en œuvre du routage frontal très simple et flexible. Cet article expliquera comment utiliser ReactRouter et fournira quelques exemples de code spécifiques. Pour installer ReactRouter en premier, nous avons besoin

Comment créer des applications de traitement de données en temps réel à l'aide de React et Apache Kafka Comment créer des applications de traitement de données en temps réel à l'aide de React et Apache Kafka Sep 27, 2023 pm 02:25 PM

Comment utiliser React et Apache Kafka pour créer des applications de traitement de données en temps réel Introduction : Avec l'essor du Big Data et du traitement de données en temps réel, la création d'applications de traitement de données en temps réel est devenue la priorité de nombreux développeurs. La combinaison de React, un framework front-end populaire, et d'Apache Kafka, un système de messagerie distribué hautes performances, peut nous aider à créer des applications de traitement de données en temps réel. Cet article expliquera comment utiliser React et Apache Kafka pour créer des applications de traitement de données en temps réel, et

PHP, Vue et React : Comment choisir le framework front-end le plus adapté ? PHP, Vue et React : Comment choisir le framework front-end le plus adapté ? Mar 15, 2024 pm 05:48 PM

PHP, Vue et React : Comment choisir le framework front-end le plus adapté ? Avec le développement continu de la technologie Internet, les frameworks front-end jouent un rôle essentiel dans le développement Web. PHP, Vue et React sont trois frameworks front-end représentatifs, chacun avec ses propres caractéristiques et avantages. Lorsqu'ils choisissent le framework front-end à utiliser, les développeurs doivent prendre une décision éclairée en fonction des besoins du projet, des compétences de l'équipe et des préférences personnelles. Cet article comparera les caractéristiques et les usages des trois frameworks front-end PHP, Vue et React.

Composants angulaires et leurs propriétés d'affichage : comprendre les valeurs par défaut non bloquantes Composants angulaires et leurs propriétés d'affichage : comprendre les valeurs par défaut non bloquantes Mar 15, 2024 pm 04:51 PM

Le comportement d'affichage par défaut des composants du framework Angular ne concerne pas les éléments au niveau du bloc. Ce choix de conception favorise l'encapsulation des styles de composants et encourage les développeurs à définir consciemment la manière dont chaque composant est affiché. En définissant explicitement l'affichage des propriétés CSS, l'affichage des composants angulaires peut être entièrement contrôlé pour obtenir la mise en page et la réactivité souhaitées.

Comment ouvrir les paramètres de l'ancienne version des composants Win10 Comment ouvrir les paramètres de l'ancienne version des composants Win10 Dec 22, 2023 am 08:45 AM

Les composants de l'ancienne version de Win10 doivent être activés par les utilisateurs eux-mêmes dans les paramètres, car de nombreux composants sont généralement fermés par défaut. Nous devons d'abord entrer les paramètres. L'opération est très simple. Suivez simplement les étapes ci-dessous. composants de version ? Ouvrir 1. Cliquez sur Démarrer, puis cliquez sur « Système Win » 2. Cliquez pour accéder au Panneau de configuration 3. Cliquez ensuite sur le programme ci-dessous 4. Cliquez sur « Activer ou désactiver les fonctions Win » 5. Ici, vous pouvez choisir ce que vous voulez. ouvrir

See all articles