Table des matières
2. Structurez vos composants et vos histoires
3. Utilisez des args et des contrôles pour des tests dynamiques
4. Document avec MDX et ajoutez des directives de conception
5. Intégrer les jetons de conception et le thème
6. Ajouter les tests et l'automatisation
Réflexions finales
Maison interface Web js tutoriel Construire un système de conception avec livre de contes et réagir

Construire un système de conception avec livre de contes et réagir

Jul 30, 2025 am 05:05 AM
Concevoir le système

Tout d'abord, utilisez NPX HistBook init pour installer et configurer le livre de contes dans React Project, exécuter NPM Run Storybook pour démarrer le serveur de développement local; 2. Organisez la structure des fichiers de composants par fonction ou type, et créez des fichiers .stories.js correspondants pour définir différents états dans chaque répertoire de composants; 3. Utilisez les systèmes Args and Controls de Storybook pour réaliser des ajustements d'attribut dynamiques pour faciliter les tests de divers états interactifs; 4. Utilisez des fichiers MDX pour écrire des documents texte riches contenant des spécifications de conception, des instructions d'accessibilité, etc., et prendre en charge le chargement MDX via la configuration; 5. Définissez les jetons de conception à travers des thèmes et utilisez TheProvider pour injecter globalement les styles de thème dans Aperçu.js; 6. Intégrer la bibliothèque de tests de plaisanterie et de réaction effectue des tests unitaires, des tests de régression visuelle avec chromatique et vérifie les problèmes d'accessibilité via @ srononage / addon-a11y. Enfin, un système de conception évolutif qui prend en charge le développement indépendant, les documents visuels, les tests automatisés et favorise la collaboration de conception et de développement. Ce système peut obtenir une réutilisation efficace entre les équipes en itérant progressivement les composants, devenant un outil nécessaire pour améliorer la cohérence de l'interface utilisateur et l'efficacité de développement.

Construire un système de conception avec livre de contes et réagir

La construction d'un système de conception avec StoryBook et React est un moyen puissant de créer des composants d'interface utilisateur cohérents et réutilisables qui évoluent entre les équipes et les produits. Le livre de contes fournit un environnement de développement isolé pour les composants de l'interface utilisateur, ce qui facilite la création, les tester et les documenter de manière isolée, sans s'appuyer sur l'application complète. Lorsqu'il est associé à React, ce combo devient une configuration incontournable pour les systèmes de conception modernes.

Construire un système de conception avec livre de contes et réagir

Voici comment l'aborder efficacement.


1. Configurez le livre de contes avec réact

Commencez par ajouter un livre de contes à votre projet React. Si vous utilisez une application Create React ou une configuration React standard, la manière la plus simple consiste à utiliser la CLI automatisée:

Construire un système de conception avec livre de contes et réagir
 NPX Historbook init

Cette commande installe StoryBook, ajoute les fichiers de configuration nécessaires et configure des exemples d'histoires. Une fois terminé, courez:

 NPM Run Storybook

Cela démarre le serveur de développement de Storybook, généralement sur http://localhost:6006 , où vous pouvez voir vos composants en temps réel.

Construire un système de conception avec livre de contes et réagir

Conseil: la commande init fonctionne bien avec la plupart des paramètres de réact, y compris Vite et Next.js. Si vous utilisez une configuration WebPack personnalisée, vous devrez peut-être ajuster .storybook/main.js en conséquence.


2. Structurez vos composants et vos histoires

Une structure de fichiers bien organisée est la clé de la maintenabilité. Composants de groupe logiquement - typiquement par caractéristique ou type (par exemple, atoms , molecules , organisms ) ou par le Button , la forme, Form , Navigation .

Exemple de structure:

 src /
├til composants /
│ ├fiquement / bouton /
│ │ ├ ├fique
│ │ ├ --met Button.stories.js
│ └── Button.module.css
│ ├fique
│ │ ├fique
│ └fiques
├tilil / styles /
│ └── thème.js

Dans chaque fichier .stories.js , définissez comment le composant doit être rendu dans différents états:

 // Button.stories.js
import {Button} de './button';

Exporter par défaut {
  Titre: «Composants / Button»,
  Composant: bouton,
  Argtypes: {
    variante: {contrôle: 'select', options: ['primaire', 'secondaire']},
  },
};

exportation const primaire = {
  args: {
    Étiquette: «cliquez sur moi»,
    variante: «primaire»,
  },
};

Export const Disabled = {
  args: {
    Étiquette: «handicapé»,
    Désactivé: vrai,
  },
};

Cela crée des commandes interactives (comme les caisses pour les accessoires) et permet aux concepteurs et aux développeurs d'explorer visuellement les variations.


3. Utilisez des args et des contrôles pour des tests dynamiques

Le système Args de StoryBook vous permet de modifier les entrées des composants à la volée. Combinés avec des contrôles , les utilisateurs peuvent modifier les accessoires directement dans l'interface utilisateur, pour tester les cas de bord et présenter la flexibilité.

Exemple:

 Argtypes: {
  Taille: {Control: 'Radio', Options: ['Small', 'Medium', 'Large']},
  onClick: {Action: 'cliquer'}, // Logs clique
}

Cela signifie que l'AQ, les PM ou les concepteurs peuvent interagir avec le bouton et voir comment il se comporte lorsqu'il est cliqué ou redimensionné, sans toucher le code.

Conseil de pro: utilisez controls: { exclude: ['id', 'className'] } pour masquer les accessoires internes ou non visuels du panneau de contrôle.


4. Document avec MDX et ajoutez des directives de conception

Aller au-delà des exemples de code. Utilisez MDX (Markdown JSX) pour rédiger une documentation riche qui comprend des jetons de conception, des directives d'utilisation, des notes d'accessibilité et même des liens FIGMA.

Créer un fichier Button.stories.mdx :

 Importer {Meta, Story, Canvas} de '@ Storybook / Blocks';
Importer * comme boutonstories de './button.stories.js';

<Meta Title = "Components / Button" Component = {Button} />

# Bouton

Utilisez des boutons pour déclencher des actions. Préférez les boutons principaux pour les actions principales, secondaire pour les alternatives.

<lebvas>
  <Story of = {Buttonstories.primary} />
</ Canvas>

## Accessibilité

Incluez toujours les étiquettes descriptives. Évitez les boutons d&#39;icônes uniquement à moins que cela ne soit correctement étiqueté avec «Aria-Label».

Configurez ensuite le livre de contes pour charger les fichiers MDX en mettant à jour .storybook/main.js :

 module.exports = {
  Histoires: [&#39;../src/**/*.stories.@(js|jsx|ts|tsx|mdx)&#39;],
  // ...
};

Maintenant, votre système de conception devient un guide de style vivant.


5. Intégrer les jetons de conception et le thème

Partagez des styles visuels (couleurs, typographie, espacement) via un objet thème, à l'aide styled-components , emotion ou de CSS-in-JS.

Exemple de thème:

 // thème.js
Exportation const thème = {
  Couleurs: {
    Primaire: &#39;# 007BFF&#39;,
    secondaire: &#39;# 6C757D&#39;,
  },
  Espacement: (facteur) => `$ {0,5 * facteur} rem`,
  Typographie: {
    En-tête: «Bold 1.5rem System-UI»,
  },
};

Enveloppez vos histoires avec un décorateur pour appliquer le thème à l'échelle mondiale dans .storybook/preview.js :

 import {themeprovider} à partir de «components stylisés»;
import {thème} de &#39;../src/styles/theme&#39;;

Exporter des décorateurs de const = [
  (Histoire) => (
    <ThemeProvider Theme = {thème}>
      <Story />
    </methEprovider>
  ),
]]

Maintenant, tous les composants rendent avec un style cohérent.


6. Ajouter les tests et l'automatisation

Un système de conception robuste a besoin de tests. Combiner:

  • Jest React Bibliothèque de tests pour les tests d'unité et de comportement.
  • Chromatique (un module complémentaire de livre de contes) pour les tests de régression visuelle.

Installer chromatique:

 npx chromatique --project-token = <Your-Token>

Il fonctionne dans CI et compare chaque histoire aux versions précédentes, en attrapant des changements visuels involontaires.

Envisagez également d'ajouter un addon A11y pour assister à des problèmes d'accessibilité:

 NPM Install @ Storybook / Addon-A11y

Puis activez-le dans .storybook/main.js :

 Addons: [&#39;@ Storybook / Addon-A11y&#39;];

Vous verrez maintenant un onglet d'accessibilité dans l'interface utilisateur avec des vérifications automatisées.


Réflexions finales

La construction d'un système de conception avec StoryBook et React ne concerne pas seulement les composants - il s'agit de créer un langage partagé entre la conception et le développement. Avec la bonne configuration, vous obtenez:

  • Développement de composants isolés
  • Documentation interactive
  • Tests visuels et cohérence
  • Interfaces conviviales de collaboration

Démarrez petit (boutons, entrées), appliquez la cohérence tôt et se développez de manière itérative. Au fil du temps, votre système de conception devient un multiple de force pour les équipes de produits.

Fondamentalement, si vous utilisez React et que vous vous souciez de la qualité de l'interface utilisateur, le livre de contes n'est pas facultatif - c'est essentiel.

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

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)

Sujets chauds

Tutoriel PHP
1535
276
Appareils et contextes avancés JavaScript Appareils et contextes avancés JavaScript Jul 24, 2025 am 12:42 AM

La portée de JavaScript détermine la portée d'accessibilité des variables, qui sont divisées en étendue globale, fonction et au niveau du bloc; Le contexte détermine la direction de cela et dépend de la méthode d'appel de fonction. 1. Les étendues incluent la portée globale (accessible n'importe où), la portée de la fonction (valide uniquement dans la fonction) et la portée au niveau du bloc (LET et const sont valides dans {}). 2. Le contexte d'exécution contient l'objet variable, la chaîne de portée et les valeurs de cela. Cela pointe vers global ou non défini dans la fonction ordinaire, l'appel de méthode pointe vers l'objet d'appel, le constructeur pointe vers le nouvel objet, et peut également être explicitement spécifié par appel / application / liaison. 3. La fermeture fait référence aux fonctions accédant et en se souvenant des variables de portée externes. Ils sont souvent utilisés pour l'encapsulation et le cache, mais peuvent provoquer

Exploration des règles de coercition de type en javascript Exploration des règles de coercition de type en javascript Jul 21, 2025 am 02:31 AM

La coulée de type est le comportement de la conversion automatique d'un type de valeur en un autre type en JavaScript. Les scénarios courants incluent: 1. Lorsque vous utilisez des opérateurs, si un côté est une chaîne, l'autre côté sera également converti en une chaîne, comme '5' 5. Le résultat est "55"; 2. Dans le contexte booléen, les valeurs non cooliennes seront implicitement converties en types booléens, tels que des chaînes vides, 0, nuls, non définies, etc., qui sont considérées comme fausses; 3. Null participe aux opérations numériques et sera convertie en 0, et non défini sera converti en NAN; 4. Les problèmes causés par la conversion implicite peuvent être évitées grâce à des fonctions de conversion explicites telles que Number (), String () et Boolean (). La maîtrise de ces règles aide

API de composition Vue 3 Vs API Options: une comparaison détaillée API de composition Vue 3 Vs API Options: une comparaison détaillée Jul 25, 2025 am 03:46 AM

CompositionAPI dans Vue3 convient plus à la logique complexe et à la dérivation de type, et OptionsAPI convient aux scénarios et débutants simples; 1. OptionsAPI organise le code en fonction d'options telles que les données et les méthodes, et a une structure claire mais les composants complexes sont fragmentés; 2. CompositionAPI utilise la configuration pour concentrer la logique liée, ce qui est propice à la maintenance et à la réutilisation; 3. CompositionAPI réalise la réutilisation logique sans conflit et paramétrisable par le biais de fonctions composables, ce qui est mieux que le mixin; 4. CompositionAPI a une meilleure prise en charge de la dérivation de type dactylographiée et de type plus précise; 5. Il n'y a pas de différence significative dans le volume de performances et d'emballage des deux; 6.

Maîtriser les modèles de concurrence JavaScript: les travailleurs du web contre les threads Java Maîtriser les modèles de concurrence JavaScript: les travailleurs du web contre les threads Java Jul 25, 2025 am 04:31 AM

Il existe une différence essentielle entre les travailleurs Web de JavaScript et Javathreads dans un traitement simultané. 1. JavaScript adopte un modèle unique. WebWorkers est un fil indépendant fourni par le navigateur. Il convient pour effectuer des tâches longues qui ne bloquent pas l'interface utilisateur, mais ne peuvent pas utiliser le DOM; 2. Java prend en charge le multithreading réel à partir du niveau de la langue, créé via la classe de threads, adapté à un traitement simultanée complexe et côté serveur; 3. Les travailleurs Web utilisent PostMessage () pour communiquer avec le fil principal, qui est hautement sécurisé et isolé; Les threads Java peuvent partager la mémoire, de sorte que les problèmes de synchronisation doivent être prêts à prêter attention; 4. Les travailleurs Web sont plus adaptés à l'informatique parallèle frontale, comme le traitement d'image, et

Comment créer et ajouter des éléments dans JS? Comment créer et ajouter des éléments dans JS? Jul 25, 2025 am 03:56 AM

Utilisez Document.CreateElement () pour créer de nouveaux éléments; 2. Personnaliser les éléments via TextContent, ClassList, SetAttribute et d'autres méthodes; 3. Utilisez des méthodes APPEDCHILD () ou plus flexibles APPEND () pour ajouter des éléments au DOM; 4. Utiliser éventuellement INSERTBEFORE (), avant () et d'autres méthodes pour contrôler la position d'insertion; Le processus complet consiste à créer → Personnaliser → Ajouter, et vous pouvez mettre à jour dynamiquement le contenu de la page.

Construire un outil CLI avec Node.js Construire un outil CLI avec Node.js Jul 24, 2025 am 03:39 AM

Initialiser le projet et créer package.json; 2. Créez un script d'entrée index.js avec shebang; 3. Registre des commandes via des champs bin dans package.json; 4. Utilisez des Yargs et d'autres bibliothèques pour analyser les paramètres de ligne de commande; 5. Utilisez le test local NPMLink; 6. Ajouter l'aide, la version et les options pour améliorer l'expérience; 7. Publier éventuellement via NPMPublish; 8. Affectuer éventuellement l'achèvement automatique avec Yargs; Enfin, créez des outils CLI pratiques grâce à une structure raisonnable et à une conception de l'expérience utilisateur, effectuer des tâches d'automatisation ou distribuer des widgets et se terminer par des phrases complètes.

Types conditionnels avancés en dactylographie Types conditionnels avancés en dactylographie Aug 04, 2025 am 06:32 AM

Les types de conditions avancées de TypeScript implémentent le jugement logique entre les types via TextendU? X: Y Syntaxe. Ses capacités de base se reflètent dans les types de conditions distribuées, l'inférence de type inférieure et la construction d'outils de type complexe. 1. Le type conditionnel est distribué dans les paramètres de type nu et peut automatiquement diviser le type de joint, tel que pour obtenir la chaîne [] | nombre []. 2. Utiliser la distribution pour construire des outils de filtrage et d'extraction: exclut exclut les types via TextendU? Never: T, extraire extrait les points communs via TextendU? T: jamais, et des filtres non nuls nuls / non définis. 3

Architecture Micro Frontend: un guide de mise en œuvre pratique Architecture Micro Frontend: un guide de mise en œuvre pratique Aug 02, 2025 am 08:01 AM

MicrofronttendSSolvescalingCallegengeSInLargeTeamsByAnabled indépendante développement et élaboration de choOsanIntegrationsStrategy: UseModuleFederationInwebpack5ForruntimeLoadingAndTrue Independence, Build-Time IntegrationForsIpleSetups, Oriframes / webcomponents webcomponents

See all articles