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 중국어 웹사이트의 기타 관련 기사를 참조하세요!