在Javascript中'冻结'数组?

问题描述 投票:29回答:2

由于ECMA-262规范Javascript已经获得了Object.freeze()方法,该方法允许添加或删除其属性无法更改的对象。

var obj = {'a':1, 'b:2'};
Object.freeze(obj);
Object.isFrozen(obj);       // returns true
obj.a = 10;                 // new assignment has no affect
obj.a;                      // returns 1

到现在为止还挺好。

我想知道,freeze()是否也适用于数组。

var arr = [1, 2];
Object.freeze(arr);
Object.isFrozen(arr);      // returns true
arr[0] = 10;
arr;                       // returns [10, 2] ... ouch!

也许我错了,但我的印象是,Array继承自Object。

typeof obj                 // "object"
typeof arr                 // "object"

任何想法,指针,启示都将受到高度赞赏。

javascript arrays object freeze
2个回答
33
投票

是的,冻结应该适用于Arrays,您遇到的行为显然是一个实现错误。

这个错误可能与数组对象实现自定义[[DefineOwnProperty]]内部方法(使length属性有效的魔力)这一事实有关。

我刚刚在两个实现上测试它并且它正常工作(Chrome 16.0.888和Firefox Aurora 8.02a)。

关于你的第二个问题,数组对象继承自Array.prototype继承自Object.prototype,例如,你可以直接从数组对象访问Object.prototype中的非阴影方法:

['a'].hasOwnProperty('0'); // true

但这与typeof的工作方式无关,这个算子将返回任何对象的'object',无论其类型,以及人们一直抱怨的null值。

typeof运算符的其余可能返回值对应于语言的原始类型,Number,String,Boolean,Symbol和Undefined。


0
投票

而不是冻结,使用扩展运算符来复制事物而不修改它们(如果您使用的是转换器,当然):

const second = {
  ...first,
  test: 20
}
© www.soinside.com 2019 - 2024. All rights reserved.