TypeError: "x" is read-only

메시지

 TypeError: "x" is read-only (Firefox) TypeError: 0 is read-only (Firefox) TypeError: Cannot assign to read only property 'x' of #<Object> (Chrome) TypeError: Cannot assign to read only property '0' of [object Array] (Chrome) 

에러 유형

무엇이 잘못 된 걸까?

전역변수 또는 객체 프로퍼티가 읽기 전용으로 할당된 경우입니다.(엄밀히 따지자면 쓰기가 불가능한 데이터 속성입니다.)

이 에러는 엄격모드에서만 등장합니다. 엄격하지 않은 모드에서는 읽기전용 속성은 묵시적으로 무시됩니다.

예시

적절하지 않은 예

읽기 전용 속성은 아주 흔한 것은 아니지만, Object.defineProperty()Object.freeze() 를 이용해 만들어 질 수 있습니다.

js
"use strict"; var obj = Object.freeze({ name: "Elsa", score: 157 }); obj.score = 0; // TypeError ("use strict"); Object.defineProperty(this, "LUNG_COUNT", { value: 2, writable: false }); LUNG_COUNT = 3; // TypeError ("use strict"); var frozenArray = Object.freeze([0, 1, 2]); frozenArray[0]++; // TypeError 

자바 스크립트에는 몇 가지 읽기 전용 속성이 내장되어 있습니다. 아마도 수학적 상수를 재정의하려고 한 것 같습니다.

js
"use strict"; Math.PI = 4; // TypeError 

이렇게는 불가능합니다.

전역변수 undefined 또한 읽기전용으로, 사람들이 모두 좋아하지 않는 "undefined is not a function" 에러가 다음과 같은 경우 등장합니다:

js
"use strict"; undefined = function () {}; // TypeError: "undefined" is read-only 

적절한 예

js
"use strict"; var obj = Object.freeze({ name: "Score", points: 157 }); obj = { name: obj.name, points: 0 }; // replacing it with a new object works ("use strict"); var LUNG_COUNT = 2; // a `var` works, because it's not read-only LUNG_COUNT = 3; // ok (anatomically unlikely, though) 

더보기