> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 개체의 진정한 전체 복사본을 만드는 방법은 무엇입니까?

JavaScript 개체의 진정한 전체 복사본을 만드는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-26 02:03:10
원래의
750명이 탐색했습니다.

How to Create a True Deep Copy of a JavaScript Object?

JavaScript 개체를 올바르게 복제하는 방법

JavaScript 개체 복제는 다양한 프로그래밍 시나리오에서 중요한 작업입니다. 그러나 원본에 대한 변경 사항에 영향을 받지 않는 개체의 복사본을 만드는 것은 JavaScript 개체 시스템의 복잡성으로 인해 어려울 수 있습니다.

기본 복사 방법의 함정

JavaScript의 기본 개체 할당 연산자(예: x = y)는 원본 객체에 대한 참조만 생성합니다. x 또는 y를 변경하면 두 개체 모두에 영향을 미칩니다. 또한 내장 JavaScript 개체(예: 배열, 날짜)에서 파생된 개체를 복사하면 원치 않는 속성이 발생할 수 있습니다.

종합 복제 솔루션

JavaScript 개체의 전체 복사본을 생성하려면 다음을 고려하세요. 다음과 같은 포괄적인 솔루션:

function clone(obj) {
  if (null == obj || "object" != typeof obj) return obj;

  var copy = obj.constructor();
  for (var attr in obj) {
    if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]);
  }
  return copy;
}
로그인 후 복사

이 함수는 객체의 속성을 순회하고 다음을 사용하여 새 객체를 생성하는 재귀적 접근 방식을 사용합니다. 각 속성 값에 대해 별도의 인스턴스를 사용합니다. 열거 불가능하고 숨겨진 속성을 제외하면서 null, 정의되지 않음 및 다양한 내장 객체 유형의 경우를 처리합니다.

가장자리 사례 및 가정

솔루션은 대부분의 시나리오를 다루지만 다음을 가정합니다. 개체 데이터가 트리 구조를 형성한다는 것은 개체 내에 순환 참조가 없음을 의미합니다. 또한 복제된 개체를 올바르게 인스턴스화하려면 개체 생성자에 대한 지식이 필요합니다.

구조적 복제(ES2022 업데이트)

최신 브라우저에서 구조적 복제 표준은 보다 강력하고 효율적인 방법을 제공합니다. 객체의 깊은 복사본을 만듭니다. StructuredClone() 함수는 숨겨진 속성과 순환 참조를 유지하면서 객체 전체를 복제합니다.

const clone = structuredClone(object);
로그인 후 복사

객체 복제는 복잡한 작업일 수 있다는 점을 기억하고 특정 요구 사항에 따라 각 접근 방식의 제한 사항을 고려하세요. 귀하의 신청서를 확인하세요.

위 내용은 JavaScript 개체의 진정한 전체 복사본을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿