"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Copie superficielle ou profonde d'objets en JavaScript

Copie superficielle ou profonde d'objets en JavaScript

Publié le 2024-11-08
Parcourir:749

Shallow vs Deep Copy of Objects in JavaScript

Lorsque nous devons copier un objet vers un autre objet, nous utilisons généralement quelque chose comme ceci :


const mainObject = { id: 1 };
const secondaryObject = { ...mainObject };


Mais cela ne fonctionne que pour copier les propriétés superficielles de l'objet. Si nous avons un cas comme le code suivant, le scénario change :


const mainObject = { id: 1, user: { name: 'John Doe', age: 30 } };
const secondaryObject = { ...mainObject };


L'utilisateur de la propriété ne sera pas copié ; il sera toujours lié à mainObject. Ainsi, si nous modifions la propriété user, cela affectera également mainObject. Pour résoudre ce problème, nous pouvons procéder comme suit :


const mainObject = { id: 1, user: { name: 'John Doe', age: 30 } };
const deepCopy = JSON.parse(JSON.stringify(mainObject ));


Maintenant, nous avons une copie complète de mainObject, avec deux adresses mémoire distinctes.

Déclaration de sortie Cet article est reproduit sur : https://dev.to/claudioguedes/shallow-vs-deep-copy-of-objects-in-javascript-3d2o?1 En cas de violation, veuillez contacter [email protected] pour supprimer il
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3