>웹 프론트엔드 >JS 튜토리얼 >`Array.prototype.fill()`이 복사본 대신 객체 참조를 생성하는 이유는 무엇입니까?

`Array.prototype.fill()`이 복사본 대신 객체 참조를 생성하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-13 07:55:12984검색

Why Does `Array.prototype.fill()` Create Object References Instead of Copies?

Array.prototype.fill()의 객체 참조

Array.prototype.fill()을 사용하여 객체로 배열을 초기화하는 경우, 이 메서드는 각 요소에 대해 새 인스턴스를 생성하는 대신 동일한 개체에 대한 참조를 전달한다는 점에 유의하는 것이 중요합니다. 이로 인해 초기화 후 개체의 속성을 수정할 때 예기치 않은 동작이 발생할 수 있습니다.

다음 예를 고려하십시오.

var arr = new Array(2).fill({});
arr[0] === arr[1]; // true
arr[0].test = 'string';
arr[1].test === 'string'; // also true

이 예에서는 두 배열 요소가 동일한 개체 참조로 초기화됩니다. 결과적으로 arr[0]과 arr[1]은 모두 동일한 객체를 참조합니다. 테스트 속성이 arr[0]에 설정되면 공유 참조로 인해 arr[1]에도 자동으로 설정됩니다.

이 문제를 방지하려면 대신 임의의 값으로 배열을 채우고 그런 다음 map()을 사용하여 각 요소에 대한 새 개체를 만듭니다.

var arr = new Array(2).fill(undefined).map(u => ({}));
var arr = new Array(2).fill().map(Object);

이 예에서는 처음에 정의되지 않은 값 또는 null 값이 배열을 채우는 데 사용됩니다. 그 후, map()을 사용하여 각 요소에 대한 새 개체를 생성하고 배열을 개별 개체로 효과적으로 채웁니다.

위 내용은 `Array.prototype.fill()`이 복사본 대신 객체 참조를 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.