Quando precisamos copiar um objeto para outro objeto, geralmente usamos algo assim:
const mainObject = { id: 1 }; const secondaryObject = { ...mainObject };
Mas isso só funciona para copiar as propriedades superficiais do objeto. Se tivermos um caso como o código a seguir, o cenário muda:
const mainObject = { id: 1, user: { name: 'John Doe', age: 30 } }; const secondaryObject = { ...mainObject };
O usuário da propriedade não será copiado; ainda estará relacionado ao mainObject. Portanto, se alterarmos a propriedade do usuário, isso também afetará o mainObject. Para resolver isso, podemos fazer o seguinte:
const mainObject = { id: 1, user: { name: 'John Doe', age: 30 } }; const deepCopy = JSON.parse(JSON.stringify(mainObject ));
Agora, temos uma cópia profunda do mainObject, com dois endereços de memória distintos.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3