이 글은 js의 딥 카피와 얕은 카피에 대한 간략한 분석을 제공합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
딥 카피와 얕은 카피는 사실 상대적으로 기본적인 두 가지 개념이지만, 여전히 매우 흥미로운 작은 세부 사항이 많기 때문에 정리하고 싶습니다.
깊은 복사와 얕은 복사는 모두가 자주 듣는 두 가지 용어입니다. 둘의 차이점은 무엇인가요?
먼저 얕은 사본이 무엇인지 살펴보겠습니다.
var obj1 = { a: 1, b: 2 }; var obj2 = obj1; obj2.a = 3; console.log(obj1); // { a: 3, b: 2 } console.log(obj2); // { a: 3, b: 2 }
obj1을 obj2에 할당하고 obj2의 해당 속성 값도 변경한 이유는 무엇입니까?
얕은 복사본은 실제로 참조의 복사본이므로 둘 다 여전히 메모리 에서 동일한 주소를 가리킵니다. 즉, obj1과 obj2는 실제로 동일한 객체를 가리킵니다. 예를 들어 1호실이 2호실로 바뀌었지만 이 방은 여전히 같은 방인 것 같습니다.
Then 딥 카피는 두 개가 서로 다른 메모리 주소를 가리킨다는 의미이며, 이것이 진정한 카피 입니다. 위의 방을 예로 들어보겠습니다. 즉, 집 번호만 변경한 것이 아니라 실제로 새 방을 열었습니다.
Object.sign()은 우리가 자주 사용하는 메소드입니다. 사실 이 메소드는 얕은 복사입니다. 하지만 여기에는 특별한 점이 있습니다. 즉, 첫 번째 레이어의 전체 복사본을 처리할 수 있다는 것입니다.
var obj1 = { a: 1, b: { c: 2 } }; var obj2 = Object.assign({}, obj1); obj2.a = 3; obj2.b.c = 3; console.log(obj1); // { a: 1, b: { c: 3 } } console.log(obj2); // { a: 3, b: { c: 3 } }
위의 예를 보면 a 속성의 값은 변경되지 않았지만 b 속성의 c 값은 변경되었습니다.
이것은 깊은 복사를 구현하는 데 가장 일반적으로 사용되는 방법입니다. 예를 살펴보세요. #🎜🎜 #
var obj1 = { a: { b: 1 } }; var obj2 = JSON.parse(JSON.stringify(obj1));
한 줄만 사용하면 됩니다. 게다가, lodash는 매우 강력한 라이브러리이며 제공되는 방법은 정말 게으른 사람들에게 꼭 필요한 것입니다.
위 내용은 js의 딥 카피와 얕은 카피에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!