Maison > interface Web > js tutoriel > Comment puis-je mettre à jour efficacement des objets dans un tableau dans ReactJS ?

Comment puis-je mettre à jour efficacement des objets dans un tableau dans ReactJS ?

Susan Sarandon
Libérer: 2024-12-03 16:42:11
original
626 Les gens l'ont consulté

How Can I Efficiently Update Objects Within an Array in ReactJS?

Mise à jour d'objets dans un tableau dans ReactJS : un guide complet

Dans ReactJS, lorsqu'il s'agit de tableaux dans le cadre de l'état, la mise à jour des objets dans ces tableaux peut être un problème. tâche difficile. Cet article vous fournira une solution optimale à ce problème.

En considérant l'exemple présenté dans le tutoriel :

var CommentBox = React.createClass({
  getInitialState: function() {
    return {data: [
      { id: 1, author: "john", text: "foo" },
      { id: 2, author: "bob", text: "bar" }
    ]};
  },
  handleCommentEdit: function(id, text) {
    var existingComment = this.state.data.filter({ function(c) { c.id == id; }).first();
    var updatedComments = ??; // not sure how to do this  

    this.setState({data: updatedComments});
  }
}
Copier après la connexion

Pour mettre à jour un objet dans le tableau 'data', nous utilisons la Méthode 'map' dans la variable updateComments :

handleCommentEdit: function(id, text) {
    this.setState({
      data: this.state.data.map(el => (el.id === id ? Object.assign({}, el, { text }) : el))
    });
}
Copier après la connexion

Cette approche utilise 'Object.assign' pour fusionner l'objet existant avec les propriétés mises à jour, garantissant ainsi immuabilité. Alternativement, vous pouvez opter pour l'opérateur « spread », qui est compatible avec ES2018 :

this.setState({
  data: this.state.data.map(el => (el.id === id ? {...el, text} : el))
});
Copier après la connexion

En suivant ces techniques, vous pouvez facilement mettre à jour les objets dans les tableaux de vos applications ReactJS.

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