> 웹 프론트엔드 > 프런트엔드 Q&A > 자바스크립트에서 객체를 복사하는 방법

자바스크립트에서 객체를 복사하는 방법

WBOY
풀어 주다: 2023-05-16 09:11:07
원래의
4836명이 탐색했습니다.

JavaScript는 객체를 조작하는 다양한 방법을 제공하는 강력한 프로그래밍 언어입니다. JavaScript에서 객체는 키-값 쌍으로 구성된 데이터 구조를 나타냅니다. 때로는 객체를 단순히 참조하는 대신 객체를 복사해야 하는 경우도 있습니다. 이 글에서는 JavaScript에서 객체를 복사하는 다양한 방법에 대해 설명합니다.

방법 1: Object.sign() 사용

Object.sign() 메서드를 사용하여 하나 이상의 원본 개체의 모든 속성을 대상 개체에 복사합니다. 이 방법은 객체를 복사하는 데에도 사용할 수 있습니다.

예를 들어, 직원 정보가 포함된 객체가 있습니다:

let employee = {
    name: 'John Doe',
    age: 25,
    position: 'Developer'
};
로그인 후 복사
로그인 후 복사

Object.sign()을 사용하여 이 객체를 복사할 수 있습니다:

let newEmployee = Object.assign({}, employee);
로그인 후 복사

이 예에서는 빈 객체를 대상 객체로 사용하고 이를 첫 번째 객체로 만듭니다. 매개변수가 전달됩니다. 소스 객체(직원)는 두 번째 매개변수입니다. 이 코드를 실행하면 직원 개체의 모든 속성과 값을 포함하는 새로운 개체 newEmployee가 생성됩니다.

여러 개체를 복사하려면 아래와 같이 순서대로 Object.asset() 메서드에 전달할 수 있습니다.

let newEmployee = Object.assign({}, employee1, employee2, employee3);
로그인 후 복사

방법 2: 스프레드 연산자 사용

스프레드 연산자(.. .), 다른 위치에서 사용할 수 있습니다. 배열이나 객체에서 스프레드 연산자를 사용하여 해당 요소를 스프레드할 수 있습니다. 소스 객체의 모든 속성을 대상 객체에 복사하려면 객체에서 스프레드 연산자를 사용하세요.

예를 들어 스프레드 연산자를 사용하여 직원 개체를 복사할 수 있습니다.

let newEmployee = { ...employee };
로그인 후 복사

이 예에서는 직원 개체에서 확산된 모든 속성을 사용하여 새 개체 newEmployee를 만듭니다. 여기서 "..."는 스프레드 연산자의 구문입니다. 직원 개체에서 모든 속성을 추출하여 새 개체 newEmployee에 추가합니다. 이 새 개체는 완전히 독립적인 개체이며 직원 개체에 대한 참조가 아닙니다.

방법 3: JSON.parse() 및 JSON.stringify() 사용

JavaScript에서는 JSON.parse() 및 JSON.stringify() 메서드를 사용하여 개체를 복사할 수도 있습니다. 개체를 JSON 문자열로 변환한 다음 해당 문자열을 새 개체로 구문 분석할 수 있습니다.

예를 들어 객체가 있습니다:

let employee = {
    name: 'John Doe',
    age: 25,
    position: 'Developer'
};
로그인 후 복사
로그인 후 복사

JSON.parse() 및 JSON.stringify() 메소드를 사용하여 이 객체를 복사할 수 있습니다.

let newEmployee = JSON.parse(JSON.stringify(employee));
로그인 후 복사

이 두 메소드의 조합은 객체를 복사하는 데 매우 유용할 수 있습니다. . 그러나 함수, 객체 참조를 포함하거나 JSON 문자열로 변환할 수 없는 특수 데이터 유형은 복사할 수 없다는 점에 유의하세요.

방법 4: 전체 복사 방법 사용

위의 방법 중 어느 것도 요구 사항을 충족할 수 없는 경우 전체 복사 방법을 사용할 수 있습니다. 전체 복사 방법은 개체 참조 및 하위 개체를 포함하여 전체 개체를 복사합니다. Lodash, Underscore.js 등과 같이 딥 카피 방법을 제공하는 라이브러리가 많이 있습니다. 여기서는 Lodash 라이브러리를 사용하여 객체를 복사하는 방법을 소개합니다.

먼저 Lodash 라이브러리를 설치해야 합니다. Node.js에서는 다음 명령을 사용하여 설치할 수 있습니다.

npm install lodash
로그인 후 복사

브라우저에서 다음 CDN 링크를 사용할 수 있습니다.

<script src="https://cdn.jsdelivr.net/lodash/4.17.15/lodash.min.js"></script>
로그인 후 복사

Lodash 라이브러리를 설치하고 도입한 후 cloneDeep() 메서드를 사용하여 생성할 수 있습니다. 객체의 원본 복사본:

let newObject = _.cloneDeep(originalObject);
로그인 후 복사

이 예에서 cloneDeep() 메서드는 OriginalObject 객체를 완전히 복사한 다음 새 객체 newObject를 반환합니다.

결론

위는 JavaScript에서 객체를 복사하는 다양한 방법입니다. 각 방법에는 필요에 따라 장단점이 있습니다. 이러한 방법을 사용하기 전에 각 방법의 작동 방식을 이해하고 특정 상황에 가장 적합한 방법을 결정하는 것이 중요합니다. 어떤 방법을 선택하든 개체 참조를 복사할 때와 개체 자체를 복사할 때를 이해해야 합니다.

위 내용은 자바스크립트에서 객체를 복사하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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