Maison > interface Web > js tutoriel > Pourquoi est-ce que j'obtiens « Violation invariante : les objets ne sont pas valides en tant qu'enfant React » dans mon application React ?

Pourquoi est-ce que j'obtiens « Violation invariante : les objets ne sont pas valides en tant qu'enfant React » dans mon application React ?

Barbara Streisand
Libérer: 2024-11-08 04:00:02
original
332 Les gens l'ont consulté

Why Am I Getting

Erreur React : les objets en tant qu'enfants

Dans les applications React, les erreurs « Violation invariante : les objets ne sont pas valides en tant qu'enfants React » se produisent lorsque tenter de restituer un objet en tant qu'enfant d'un composant. Ce problème survient lorsque l'enfant attend une chaîne, un nombre ou un élément mais reçoit un objet à la place.

Dans l'exemple donné, dans la fonction map de la méthode de rendu, this.onItemClick.bind(this, item ) transmet de manière incorrecte l'intégralité de l'objet événement en tant que propriété au gestionnaire onClick. Par conséquent, le gestionnaire d'événements onClick reçoit l'événement avec ses propriétés en tant qu'objet, déclenchant l'erreur.

Pour résoudre ce problème, vous pouvez soit utiliser une fonction de flèche à l'intérieur de la carte pour gérer l'événement click et transmettre l'argument nécessaire. :

render() {
    const items = ['EN', 'IT', 'FR', 'GR', 'RU'].map((item) => {
      return (<li onClick={(e) => this.onItemClick(e, item)} key={item}>{item}</li>);
    });
    return (
      <div>
        ...
                <ul>
                  {items}
                </ul>
         ...
      </div>
    );
  }
Copier après la connexion

Alternativement, si vous souhaitez conserver l'objet événement, vous pouvez lier uniquement le paramètre nécessaire :

render() {
    const items = ['EN', 'IT', 'FR', 'GR', 'RU'].map((item) => {
      return (<li onClick={this.onItemClick.bind(this, item)} key={item}>{item}</li>);
    });
    return (
      <div>
        ...
                <ul>
                  {items}
                </ul>
         ...
      </div>
    );
  }
Copier après la connexion

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!

source:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal