recherche
Maisoninterface Webtutoriel CSSGérer l'état en réagir à l'aide de net non déclaré

Gérer l'état en réagir en utilisant un nez non déclaré

Cet article s'appuie sur une discussion précédente de la gestion de l'État à l'aide de son successeur non déclaré, explorant non déclaré, son successeur. Les motifs non énoncés de NEXT se réagissent et l'API de contexte pour la gestion de l'état rationalisée, offrant une approche plus efficace que son prédécesseur, en particulier compte tenu des progrès des crochets React. Nous examinerons la gestion des états uniques et multi-composants en utilisant un nez non déclaré. La familiarité avec l'article non déclaré précédent est utile mais pas strictement requise.

Exemple de composant de formulaire minimal

Nous allons créer un formulaire de réaction simple avec une entrée de texte pour un nom et un bouton de soumission. Lors de la soumission, le nom sera affiché au-dessus du formulaire. Le code complet est disponible sur GitHub. Cet exemple utilise Create React App and Bootstrap.

Tout d'abord, configurez le projet:

 NPX Create-REACT-App Not Sated-Next-Form
CD non énoncée

Installez NON STATÉ-NET:

 # fil
fil Ajouter un net non déclaré

# npm
Installation de NPM - Save non déclaré

Importez les modules nécessaires dans App.js :

 // src / app.js
Importer React, {UseState} de 'react';
import {CreateContainer} à partir de "non déclaré-next";

Créer un crochet personnalisé:

 // src / app.js
// ... importations précédentes

const useform = () => {
  const [input, setValue] = useState ("");
  const [name, setName] = UseState ("Barney Stinson");

  const handleInput = (event) => setValue (event.target.value);
  const updateName = (event) => {
    event.PreventDefault ();
    setName (entrée);
    setValue ("");
  };

  return {entrée, nom, mancheinput, updaTename};
};

Créez un conteneur à l'aide de createContainer :

 // src / app.js
// ... code précédent

const FormContainer = createContainer (useForm);

Créez le composant de formulaire:

 // src / app.js
// ... code précédent

const form = () => {
  const form = formContainer.UseContainer ();
  retour (
    <div>
      <p>Bonjour! {form.name}</p>
      <form onsubmit="{form.updateName}">
        <input type="text" value="{form.input}" onchange="{form.handleInput}">
        <button type="submit">Sauvegarder</button>
      </form>
    </div>
  ));
};

Enveloppez le composant de formulaire avec le fournisseur dans le composant de l'application:

 const app = () => (
  <formcontainer.provider>
    <form></form>
  </formcontainer.provider>
));

Cela complète l'exemple de formulaire minimal. Essayez de créer une application simple à faire en utilisant ces concepts. Un référentiel de référence est disponible.

Partage de l'état sur plusieurs composants

Cet exemple démontre le partage de l'état entre un formulaire et une liste de tâches. Le nom de l'utilisateur, mis à jour dans le formulaire, reflétera dans la liste de tâches.

Créez un nouveau projet et installez les dépendances:

 npx création-react-appin non décontracté-next-app
CD non énoncée
fil Ajouter un shortid à net non déclaré

Créer store.js pour gérer l'état partagé:

 // src / store.js
import {UseState} de "réact";
Importer ShortID à partir de "ShortID";
import {createContainer} à partir de 'non stated-next';

const usestore = () => {
  const [input, setValue] = useState ("");
  const [name, setName] = UseState ("Barney Stinson");
  const [todos, settodos] = useState ([{id: 1, titre: 'write code'}, {id: 2, titre: 'acheter lait'}]);
  const [item, setItem] = useState ("");

  const handleInput = (event) => setValue (event.target.value);
  const updateName = (event) => {
    event.PreventDefault ();
    setName (entrée);
    setValue ("");
  };
  const handleItem = (event) => setItem (event.target.value);
  const handlesubmit = (événement) => {
    event.PreventDefault ();
    Settodos ([... Todos, {id: shortId.GenERERe (), titre: item}]);
    setItem ("");
  };

  return {entrée, nom, mancheinput, updatename, todos, item, handleItem, handlesubmit};
};

Export Const StoreContainer = CreateContainer (USESTORE);

Créer form.js :

 // src / form.js
importer réagir à partir de "réagir";
import {StoreContainer} de "./store";

const formComponent = () => {
  const form = StoreContainer.UseContainer ();
  retour (
    <div>
      <p>Bonjour! {form.name}</p>
      <form onsubmit="{form.updateName}">
        <input type="text" value="{form.input}" onchange="{form.handleInput}">
        <button type="submit">Changer de nom</button>
      </form>
    </div>
  ));
};

Exporter FormComponent par défaut;

Créer todo.js :

 // src / todo.js
importer réagir à partir de "réagir";
import {StoreContainer} de "./store";

const todocomponent = () => {
  const todo = storeContainer.UseContainer ();
  retour (
    <div>
      <p>Ajouter des todos</p>
      <form onsubmit="{todo.handleSubmit}">
        <input type="text" value="{todo.item}" onchange="{todo.handleItem}">
        <button type="submit">Ajouter</button>
      </form>
      <p>Cher {todo.name}, voici vos tâches actuelles:</p>
      <ul>
        {todo.todos.map ((item) =><li key="{item.id}"> {item.title}</li> )}
      </ul>
    </div>
  ));
};

Exporter ToDoComponent par défaut;

Mettre à jour App.js :

 importer réagir à partir de «réagir»;
Importer ToDoComponent depuis "./todo";
Importer FormComponent à partir de "./form";
import {StoreContainer} de "./store";

Function App () {
  retour (
    <storecontainer.provider>
      <formcomponent></formcomponent>
      <todocomponent></todocomponent>
    </storecontainer.provider>
  ));
}

Exporter l'application par défaut;

Cet exemple révisé fournit une illustration plus complète et fonctionnelle du partage d'états sur plusieurs composants à l'aide de Nett-Next. N'oubliez pas de gérer les erreurs potentielles et les cas de bord dans un environnement de production.

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
Le positionnement de l'ancre ne se soucie pas de l'ordre sourceLe positionnement de l'ancre ne se soucie pas de l'ordre sourceApr 29, 2025 am 09:37 AM

Le fait que le positionnement de l'ancrage évite l'ordre de source HTML est si CSS-y parce qu'il est une autre séparation des préoccupations entre le contenu et la présentation.

Que signifie marge: 40px 100px 120px 80px?Que signifie marge: 40px 100px 120px 80px?Apr 28, 2025 pm 05:31 PM

L'article traite de la propriété CSS Margin, en particulier "Marge: 40px 100px 120px 80px", son application et les effets sur la mise en page de la page Web.

Quelles sont les différentes propriétés de la frontière CSS?Quelles sont les différentes propriétés de la frontière CSS?Apr 28, 2025 pm 05:30 PM

L'article traite des propriétés des frontières CSS, en se concentrant sur la personnalisation, les meilleures pratiques et la réactivité. Argument principal: Border-Radius est le plus efficace pour les conceptions réactives.

Quels sont les arrière-plans CSS, énumérez les propriétés?Quels sont les arrière-plans CSS, énumérez les propriétés?Apr 28, 2025 pm 05:29 PM

L'article traite des propriétés de fond CSS, de leurs utilisations dans l'amélioration de la conception du site Web et des erreurs courantes à éviter. L'accent est mis sur la conception réactive en utilisant la taille de l'arrière-plan.

Quelles sont les couleurs CSS HSL?Quelles sont les couleurs CSS HSL?Apr 28, 2025 pm 05:28 PM

L'article traite des couleurs CSS HSL, de leur utilisation dans la conception Web et des avantages par rapport à RVB. L'objectif principal est d'améliorer la conception et l'accessibilité grâce à une manipulation intuitive des couleurs.

Comment pouvons-nous ajouter des commentaires dans CSS?Comment pouvons-nous ajouter des commentaires dans CSS?Apr 28, 2025 pm 05:27 PM

L'article traite de l'utilisation des commentaires dans CSS, détaillant les syntaxes de commentaires à ligne unique et multi-lignes. Il soutient que les commentaires améliorent la lisibilité, la maintenabilité et la collaboration du code, mais peuvent avoir un impact sur les performances du site Web si elles ne sont pas gérées correctement.

Que sont les sélecteurs CSS?Que sont les sélecteurs CSS?Apr 28, 2025 pm 05:26 PM

L'article traite des sélecteurs CSS, de leurs types et de l'utilisation pour le style des éléments HTML. Il compare les sélecteurs ID et classe et aborde les problèmes de performances avec des sélecteurs complexes.

Quel type de CSS détient la priorité la plus élevée?Quel type de CSS détient la priorité la plus élevée?Apr 28, 2025 pm 05:25 PM

L'article traite de la priorité CSS, en se concentrant sur les styles en ligne ayant la plus grande spécificité. Il explique les niveaux de spécificité, les méthodes de remplacement et les outils de débogage pour gérer les conflits CSS.

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

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

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel