Maison > interface Web > js tutoriel > le corps du texte

Comment fusionner des objets JavaScript dans un tableau avec des clés partagées ?

Mary-Kate Olsen
Libérer: 2024-10-30 23:43:30
original
870 Les gens l'ont consulté

How to Merge JavaScript Objects in an Array with Shared Keys?

Fusionner des objets JavaScript dans un tableau avec des clés partagées

En JavaScript, il est souvent nécessaire de combiner des objets avec des clés similaires en un seul objet . Considérons l'exemple donné :

<code class="js">const array = [
  {
    name: "foo1",
    value: "val1"
  },
  {
    name: "foo1",
    value: ["val2", "val3"]
  },
  {
    name: "foo2",
    value: "val4"
  }
];</code>
Copier après la connexion

Le but est de réorganiser ce tableau en un tableau "de sortie" où toutes les clés de valeur sont fusionnées en objets avec des noms partagés. Le résultat attendu ressemblerait à :

<code class="js">const output = [
  {
    name: "foo1",
    value: ["val1", "val2", "val3"]
  },
  {
    name: "foo2",
    value: ["val4"]
  }
];</code>
Copier après la connexion

Fusionner les objets

Une approche de ce problème consiste à utiliser les étapes suivantes :

  1. Parcourez chaque objet du tableau à l'aide de forEach().
  2. Filtrez le tableau de sortie pour trouver un objet existant avec la même clé de nom.
  3. Si un objet existant est trouvé, concaténez le valeurs de l'objet actuel à son tableau de valeurs.
  4. Si un objet existant n'est pas trouvé, créez un nouvel objet avec les propriétés de l'objet actuel et ajoutez-le au tableau de sortie.
  5. Gérez la possibilité de la valeur étant une chaîne en la convertissant en tableau.

Exemple de code

Le code suivant implémente l'approche décrite :

<code class="js">const array = [
  {
    name: "foo1",
    value: "val1"
  },
  {
    name: "foo1",
    value: ["val2", "val3"]
  },
  {
    name: "foo2",
    value: "val4"
  }
];

let output = [];

array.forEach(item => {
  const existing = output.filter(v => v.name == item.name);
  if (existing.length) {
    const existingIndex = output.indexOf(existing[0]);
    output[existingIndex].value = output[existingIndex].value.concat(item.value);
  } else {
    if (typeof item.value == 'string') item.value = [item.value];
    output.push(item);
  }
});

console.log(output);</code>
Copier après la connexion

Ce code produira le tableau de sortie souhaité dans lequel tous les objets portant le même nom verront leurs valeurs fusionnées.

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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!