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.
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