recherche
Maisoninterface Webjs tutorielPrincipes SOLID dans React : la clé pour écrire des composants maintenables

SOLID Principles in React: The Key to Writing Maintainable Components

À mesure que les applications React se développent, les choses peuvent rapidement devenir compliquées : composants gonflés, code difficile à maintenir et bugs inattendus. C’est là que les principes SOLID s’avèrent utiles. Développés à l'origine pour la programmation orientée objet, ces principes vous aident à écrire du code propre, flexible et évolutif. Dans cet article, je vais détailler chaque principe SOLID et montrer comment vous pouvez les utiliser dans React pour garder vos composants organisés, votre code plus facile à maintenir et votre application prête à se développer.

SOLID est un acronyme qui représente cinq principes de conception visant à écrire du code propre, maintenable et évolutif, à l'origine pour la programmation orientée objet mais également applicable dans React :

S : Principe de responsabilité unique : Les composants doivent avoir un seul travail ou une seule responsabilité.

O : Principe ouvert/fermé : les composants doivent être ouverts pour extension ** (facilement améliorés ou personnalisés) mais **fermés pour modification (leur code principal ne devrait pas avoir besoin changements).

L : Principe de substitution de Liskov : les composants doivent être remplaçables par leurs composants enfants sans perturber le comportement de l'application.

I : Principe de ségrégation des interfaces : Les composants ne doivent pas être forcés de dépendre de fonctionnalités inutilisées.

D : Principe d'inversion des dépendances : les composants doivent dépendre d'abstractions, et non d'implémentations concrètes.

Principe de responsabilité unique (SRP)

Pensez-y comme ceci : imaginez que vous avez un robot jouet qui ne peut faire qu'un seul travail, comme marcher. Si vous lui demandez de faire une deuxième chose, comme parler, il devient confus car il est censé se concentrer sur la marche ! Si vous voulez un autre travail, procurez-vous un deuxième robot.

Dans React, un composant ne doit faire qu'une seule chose. S'il en fait trop, comme récupérer des données, gérer les entrées de formulaire et afficher l'interface utilisateur en même temps, cela devient compliqué et difficile à gérer.

const UserCard = () => {
  const [user, setUser] = useState(null);

  useEffect(() => {
    fetch('/api/user')
      .then(response => response.json())
      .then(data => setUser(data));
  }, []);

  return user ? ( <div>
      <h2 id="user-name">{user.name}</h2>
      <p>{user.email}</p>
    </div> ) : <p>Loading...</p>;
};

Ici, la UserCard est responsable à la fois de la récupération des données et du rendu de l'interface utilisateur, ce qui enfreint le principe de responsabilité unique.

const useFetchUser = (fetchUser) => {
  const [user, setUser] = useState(null);

  useEffect(() => {
    fetchUser().then(setUser);
  }, [fetchUser]);

  return user;
};

const UserCard = ({ fetchUser }) => {
  const user = useFetchUser(fetchUser);

  return user ? (
    <div>
      <h2 id="user-name">{user.name}</h2>
      <p>{user.email}</p>
    </div>
  ) : (
    <p>Loading...</p>
  );
};

Ici, la logique de récupération des données est déplacée vers un hook personnalisé (useFetchUser), tandis que UserCard se concentre uniquement sur le rendu de l'interface utilisateur et maintenir le SRP.

Principe ouvert/fermé (OCP)

Pensez à un personnage de jeu vidéo. Vous pouvez ajouter de nouvelles compétences au personnage (extensions) sans modifier ses capacités principales (modifications). C’est la raison d’être d’OCP : permettre à votre code de croître et de s’adapter sans altérer ce qui existe déjà.

const Alert = ({ type, message }) => {
  if (type === 'success') {
    return <div classname="alert-success">{message}</div>;
  }
  if (type === 'error') {
    return <div classname="alert-error">{message}</div>;
  }
  return <div>{message}</div>;
};

Ici, chaque fois que vous avez besoin d'un nouveau type d'alerte, vous devez modifier le composant Alert, ce qui interrompt l'OCP. chaque fois que vous ajoutez un rendu conditionnel ou changez de rendu de casse dans votre composant, vous rendez ce composant moins maintenable, car vous devez ajouter plus de conditions dans la fonctionnalité et modifier le code principal de ce composant qui rompt l'OCP.

const Alert = ({ className, message }) => (
  <div classname="{className}">{message}</div>
);

const SuccessAlert = ({ message }) => (
  <alert classname="alert-success" message="{message}"></alert>
);

const ErrorAlert = ({ message }) => (
  <alert classname="alert-error" message="{message}"></alert>
);

Maintenant, le composant Alert est ouvert pour extension (en ajoutant SuccessAlert, ErrorAlert, etc.) mais fermé pour modification car nous n'avons pas besoin de toucher au composant Alert principal pour ajouter de nouveaux types d'alertes.

Envie d'OCP ? Préférez la composition à l'héritage

Principe de substitution de Liskov (LSP)

Imaginez que vous avez un téléphone, puis que vous recevez un nouveau smartphone. Vous vous attendez à passer des appels sur votre smartphone comme vous le faisiez avec un téléphone ordinaire. Si le smartphone ne pouvait pas passer d’appels, ce serait un mauvais remplacement, non ? C'est l'essence même de LSP : les composants nouveaux ou enfants doivent fonctionner comme l'original sans casser les choses.

const Button = ({ onClick, children }) => (
  <button onclick="{onClick}">{children}</button>
);

const IconButton = ({ onClick, icon }) => (
  <button onclick="{onClick}">
    <i classname="{icon}"></i>
  </button>
);

Ici, si vous échangez le Button avec l'IconButton, vous perdez l'étiquette, brisant le comportement et les attentes.

const Button = ({ onClick, children }) => (
  <button onclick="{onClick}">{children}</button>
);

const IconButton = ({ onClick, icon, label }) => (
  <button onclick="{onClick}">
    <i classname="{icon}"></i> {label}
  </button>
);

// IconButton now behaves like Button, supporting both icon and label

Maintenant, IconButton étend correctement le comportement de Button, prenant en charge à la fois les icônes et les étiquettes, afin que vous pouvez les échanger sans interrompre la fonctionnalité. Cela suit le principe de substitution de Liskov car l'enfant (IconButton) peut remplacer le parent (Button) sans aucune surprise !

Si le composant B étend le composant A, partout où vous utilisez le composant A, vous devriez pouvoir utiliser le composant B.

Principe de ségrégation d'interface (ISP)

Imaginez que vous utilisez une télécommande pour regarder la télévision. Vous n’avez besoin que de quelques boutons comme l’alimentation, le volume et la chaîne. Si la télécommande avait des tonnes de boutons inutiles pour un lecteur DVD, une radio et des lumières, ce serait ennuyeux à utiliser.

Supposons que vous disposiez d'un composant de table de données qui nécessite de nombreux accessoires, même si le composant qui l'utilise n'en a pas tous besoin.

const DataTable = ({ data, sortable, filterable, exportable }) => (
  <div>
    {/* Table rendering */}
    {sortable && <button>Sort</button>}
    {filterable && <input placeholder="Filter">}
    {exportable && <button>Export</button>}
  </div>
);

This component forces all consumers to think about sorting, filtering, and exporting—even if they only want a simple table.

You can split the functionality into smaller components based on what’s needed.

const DataTable = ({ data }) => (
  <div>
    {/* Table rendering */}
  </div>
);

const SortableTable = ({ data }) => (
  <div>
    <datatable data="{data}"></datatable>
    <button>Sort</button>
  </div>
);

const FilterableTable = ({ data }) => (
  <div>
    <datatable data="{data}"></datatable>
    <input placeholder="Filter">
  </div>
);

Now, each table only includes the functionality that’s needed, and you’re not forcing unnecessary props everywhere. This follows ISP, where components only depend on the parts they need.

Dependency Inversion Principle (DIP)

Imagine you're building with LEGO blocks. You have a robot built with specific pieces. But what if you want to swap out its arms or legs? You shouldn't have to rebuild the whole thing—just swap out the parts. The Dependency Inversion Principle (DIP) is like this: your robot (high-level) doesn't depend on specific parts (low-level); it depends on pieces that you can change easily.

const UserComponent = () => {
  useEffect(() => {
    fetch('/api/user').then(...);
  }, []);
  return <div>...</div>;
};

This directly depends on fetch—you can’t swap it easily.

const UserComponent = ({ fetchUser }) => {
  useEffect(() => {
    fetchUser().then(...);
  }, [fetchUser]);
  return <div>...</div>;
};

Now, the fetchUser function is passed in, and you can easily swap it with another implementation (e.g., mock API, or another data source), keeping everything flexible and testable.

Final Thoughts

Understanding and applying SOLID principles in React can drastically improve the quality of your code. These principles—Single Responsibility, Open/Closed, Liskov Substitution, Interface Segregation, and Dependency Inversion—help you write components that are more modular, flexible, and easier to maintain. By breaking down responsibilities, keeping code extensible, and making sure each part of your app interacts in predictable ways, you can create React applications that scale more easily and are simpler to debug. In short, SOLID principles lead to cleaner and more maintainable codebases.

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
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
Moteurs JavaScript: comparaison des implémentationsMoteurs JavaScript: comparaison des implémentationsApr 13, 2025 am 12:05 AM

Différents moteurs JavaScript ont des effets différents lors de l'analyse et de l'exécution du code JavaScript, car les principes d'implémentation et les stratégies d'optimisation de chaque moteur diffèrent. 1. Analyse lexicale: convertir le code source en unité lexicale. 2. Analyse de la grammaire: générer un arbre de syntaxe abstrait. 3. Optimisation et compilation: générer du code machine via le compilateur JIT. 4. Exécuter: Exécutez le code machine. Le moteur V8 optimise grâce à une compilation instantanée et à une classe cachée, SpiderMonkey utilise un système d'inférence de type, résultant en différentes performances de performances sur le même code.

Au-delà du navigateur: Javascript dans le monde réelAu-delà du navigateur: Javascript dans le monde réelApr 12, 2025 am 12:06 AM

Les applications de JavaScript dans le monde réel incluent la programmation côté serveur, le développement des applications mobiles et le contrôle de l'Internet des objets: 1. La programmation côté serveur est réalisée via Node.js, adaptée au traitement de demande élevé simultané. 2. Le développement d'applications mobiles est effectué par le reactnatif et prend en charge le déploiement multiplateforme. 3. Utilisé pour le contrôle des périphériques IoT via la bibliothèque Johnny-Five, adapté à l'interaction matérielle.

Construire une application SaaS multi-locataire avec next.js (intégration backend)Construire une application SaaS multi-locataire avec next.js (intégration backend)Apr 11, 2025 am 08:23 AM

J'ai construit une application SAAS multi-locataire fonctionnelle (une application EdTech) avec votre outil technologique quotidien et vous pouvez faire de même. Premièrement, qu'est-ce qu'une application SaaS multi-locataire? Les applications saas multi-locataires vous permettent de servir plusieurs clients à partir d'un chant

Comment construire une application SaaS multi-locataire avec Next.js (Frontend Integration)Comment construire une application SaaS multi-locataire avec Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

Cet article démontre l'intégration frontale avec un backend sécurisé par permis, construisant une application fonctionnelle EdTech SaaS en utilisant Next.js. Le frontend récupère les autorisations des utilisateurs pour contrôler la visibilité de l'interface utilisateur et garantit que les demandes d'API adhèrent à la base de rôles

JavaScript: Explorer la polyvalence d'un langage WebJavaScript: Explorer la polyvalence d'un langage WebApr 11, 2025 am 12:01 AM

JavaScript est le langage central du développement Web moderne et est largement utilisé pour sa diversité et sa flexibilité. 1) Développement frontal: construire des pages Web dynamiques et des applications à une seule page via les opérations DOM et les cadres modernes (tels que React, Vue.js, Angular). 2) Développement côté serveur: Node.js utilise un modèle d'E / S non bloquant pour gérer une concurrence élevée et des applications en temps réel. 3) Développement des applications mobiles et de bureau: le développement de la plate-forme multiplateuse est réalisé par réact noral et électron pour améliorer l'efficacité du développement.

L'évolution de JavaScript: tendances actuelles et perspectives d'avenirL'évolution de JavaScript: tendances actuelles et perspectives d'avenirApr 10, 2025 am 09:33 AM

Les dernières tendances de JavaScript incluent la montée en puissance de TypeScript, la popularité des frameworks et bibliothèques modernes et l'application de WebAssembly. Les prospects futurs couvrent des systèmes de type plus puissants, le développement du JavaScript côté serveur, l'expansion de l'intelligence artificielle et de l'apprentissage automatique, et le potentiel de l'informatique IoT et Edge.

Démystifier javascript: ce qu'il fait et pourquoi c'est importantDémystifier javascript: ce qu'il fait et pourquoi c'est importantApr 09, 2025 am 12:07 AM

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Python ou JavaScript est-il meilleur?Python ou JavaScript est-il meilleur?Apr 06, 2025 am 12:14 AM

Python est plus adapté à la science des données et à l'apprentissage automatique, tandis que JavaScript est plus adapté au développement frontal et complet. 1. Python est connu pour sa syntaxe concise et son écosystème de bibliothèque riche, et convient à l'analyse des données et au développement Web. 2. JavaScript est le cœur du développement frontal. Node.js prend en charge la programmation côté serveur et convient au développement complet.

See all articles

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire