TypeError: "x" is read-only - JavaScript 编辑

报错消息

TypeError: "x" is read-only (Firefox) //格式错误:"x"只读。(x可以代表任意值)
TypeError: 0 is read-only (Firefox)
TypeError: Cannot assign to read only property 'x' of #<Object> (Chrome)
//格式错误:对象的x属性是只读的不能设置 (chrome)
TypeError: Cannot assign to read only property '0' of [object Array] (Chrome)

错误格式

TypeError

哪里出错了?

全局变量或对象属性被设置为只读 (专业点讲,就是这条数据属性禁止写入.)

这条错误值发生在strict mode code(俗称严格模式). 正常情况下,是没有报错的。

例如

无效例子(也就是下面这么做会导致报这种错)

只读属性不能直接创建, 但我们可以通过Object.defineProperty()Object.freeze()设置.

"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

还有几个JavaScript内置属性. 如果你尝试修改一个常量.

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

傻了吧,报错了

全局变量undefined也是只读的, 所以你不能忽视臭名昭著的"undefined is not a function"错误:

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

下面这样都是有效,不报错的

"use strict";
var obj = Object.freeze({name: "Score", points: 157});
obj = {name: obj.name, points: 0};   // 用一个新对象替换原来的对象(其实就是更改了对象的指针)

"use strict";
var LUNG_COUNT = 2;  //
LUNG_COUNT = 3;  //

参见

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

词条统计

浏览:71 次

字数:3874

最后编辑:6年前

编辑次数:0 次

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文