Maison >interface Web >Questions et réponses frontales >JavaScript remplace la clé de l'objet
En programmation JavaScript, faire fonctionner des objets est une exigence très courante. Il est souvent nécessaire de changer le nom de certaines clés d'un objet. Bien que JavaScript offre de nombreuses façons différentes de manipuler des objets, remplacer la clé d'un objet par une nouvelle clé peut s'avérer difficile.
Dans cet article, nous explorerons différentes manières de remplacer les clés d'un objet par de nouvelles clés en JavaScript. Nous aborderons les aspects suivants :
Qu'est-ce que le remplacement de clé d'objet
Le remplacement de clé d'objet est une opération qui nous permet de changer le nom d'une clé spécifique dans un objet JavaScript. Ceci est utile lorsque vous avez besoin d’obtenir une valeur à partir d’un objet. Par exemple, lors de la récupération de données d'objet via une API, vous devrez peut-être faire correspondre les clés de l'objet de données renvoyé avec les clés utilisées dans le magasin de données local.
Comment remplacer les clés d'objet en JavaScript
Il existe de nombreuses façons différentes de remplacer les clés d'objet en JavaScript. Les trois méthodes les plus couramment utilisées sont décrites ci-dessous.
const obj = { oldName: "value" }; obj.newName = obj.oldName; delete obj.oldName;
Dans l'extrait de code ci-dessus, nous implémentons le remplacement de clé d'objet en créant un nouveau nom de clé, en copiant la valeur de l'ancien nom de clé, puis en supprimant l'ancien nom de clé. .
const obj = { oldName: "value" }; Object .keys(obj) .forEach(key => { if (key === "oldName") { obj.newName = obj[key]; delete obj[key]; } });
Utilisez Object.keys() localement pour obtenir les clés de l'objet, puis utilisez une instruction if pour vérifier si chaque clé correspond au nom que vous souhaitez modifier. S'il y a une correspondance, la valeur est copiée dans la nouvelle clé et l'ancienne clé est supprimée.
const obj = { oldName: "value" }; const newObj = {}; newObj.newName = obj.oldName; delete newObj.oldName;
Utilisez la méthode Object.assign() d'ES6 pour le remplacement de clé
En utilisant la méthode Object.assign() d'ES6 et ses paramètres disponibles, nous pouvons gérer la tâche de remplacement de la clé d'objet JavaScript. Object.assign() est une méthode qui copie l'objet source dans l'objet cible et renvoie l'objet cible. Par conséquent, nous pouvons envoyer l’objet source avec la nouvelle clé comme paramètres pour implémenter le remplacement.
const obj = { oldName: "value" }; const newObj = Object.assign({}, obj, {newName: obj.oldName}); delete newObj.oldName;
Ici, nous utilisons Object.assign() pour créer un nouvel objet et utiliser l'ancien objet et ses propriétés comme objet source. Ensuite, en utilisant le nouveau nom de clé comme argument distinct, exprimez ce nom comme correspondant au nom de l'ancienne clé que vous souhaitez supprimer. Enfin, le remplacement de la clé est complété par la suppression de l'ancienne clé.
Utilisez la méthode de déstructuration d'objets d'ES6 pour remplacer les clés
La déstructuration d'objets dans ES6 offre une autre façon de remplacer les clés d'objet JavaScript. La déstructuration d'objets est une méthode de déstructuration des propriétés d'un objet en variables distinctes, qui peuvent avoir de nouveaux noms (variables d'alias). En utilisant la nouvelle clé comme alias, nous pouvons générer l'opération de remplacement de clé souhaitée en supprimant l'ancienne clé.
const obj = { oldName: "value" }; const {oldName:newName, ...newObj} = obj;
Ici, nous déclarons un nouvel objet et déplaçons toutes les propriétés de l'objet opéré vers le nouvel objet par affectation de déstructuration. Nous alias les anciennes clés sur le nouvel objet en utilisant "…" (opérateur spread). De cette façon, la syntaxe de déstructuration nous permet en fait de donner à notre objet cible un nouveau nom pour n'importe quelle clé cible (appelée alias).
Utilisez les méthodes Object.entries() et Object.fromEntries() pour le remplacement des clés
Object.entries() et Object.fromEntries() sont les dernières technologies, dans Introduit en ES2019. Ces méthodes simplifient grandement le remplacement de la clé d'objet.
const obj = { oldName: "value" }; const newObj = Object.fromEntries( Object.entries(obj) .map(([k, v]) => [k === "oldName" ? "newName" : k, v]) );
Ici, nous utilisons la méthode Object.entries() pour obtenir la liste des paires clé-valeur de l'objet. Nous transformons cette liste à l'aide de la méthode map(), en remplaçant les anciennes clés par de nouvelles clés si elles correspondent, puis en ajoutant chaque nouvelle paire clé-valeur à un nouvel objet. Convertissez la liste d'éléments convertie en un nouvel objet paire clé-valeur à l'aide de la méthode Object.fromEntries().
Conclusion
Le remplacement de clé d'objet est très courant pour travailler avec des données d'objet JavaScript. Nous voyons que JavaScript propose de nombreuses façons différentes d'y parvenir via le remplacement de clé d'objet JavaScript. Il est facile de supprimer et de renommer des clés dans des objets JavaScript à l'aide des méthodes ES6 standard. Pour cela nous pouvons utiliser la méthode Object.assign(), la déstructuration d'objets, les méthodes Object.keys() et Object.entries(). Ces stratégies recherchent toutes des performances, une facilité d'utilisation et une lisibilité maximales.
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!