>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 상수 개체를 수정할 수 있는 이유는 무엇입니까?

JavaScript에서 상수 개체를 수정할 수 있는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-29 01:13:10574검색

Why Can I Modify a Constant Object in JavaScript?

JavaScript의 상수 객체: 불변 속성 이해

ES6의 상수 키워드에도 불구하고 JavaScript에서는 상수 객체를 수정할 수 있는 것처럼 보입니다. 이는 특히 사양의 불변성 주장을 고려하면 혼란스러울 수 있습니다. 그럼 무슨 일이 벌어지고 있는 걸까요?

먼저 MDN 문서에 명시되어 있듯이 상수 키워드는 상수 자체의 재할당 및 재선언을 금지합니다. 그러나 객체나 배열을 수정할 때는 이를 다시 할당하거나 다시 선언하지 않습니다. 대신, 단순히 객체의 속성이나 배열의 요소를 조작하면 됩니다.

예를 고려하세요.

const x = {};
x.foo = 'bar'; // Adds a property to an existing object
const y = [];
y.push('foo'); // Appends an element to an existing array

두 경우 모두 상수 객체(x)와 배열( y) 동일한 참조를 유지합니다. 객체 자체를 변경하는 것이 아니라 해당 요소를 추가하거나 수정하는 것입니다. 이는 상수 참조의 불변성을 위반하지 않기 때문에 허용됩니다.

그러나 재할당이나 재선언은 여전히 ​​금지됩니다.

const x = {};
x = {foo: 'bar'}; // Error: Reassigning a constant
const y = ['foo'];
const y = ['bar']; // Error: Re-declaring a constant

따라서 상수 객체의 속성이나 상수 배열의 요소를 수정하는 경우 참조 자체를 바꾸거나 재정의할 수 없습니다.

위 내용은 JavaScript에서 상수 개체를 수정할 수 있는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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