1、不可扩展对象) a. E, L: {; w' P
默认情况下对象都是可以扩展的,也就是说,任何时候都可以向对象中添加属性和方法。现在使用Object.preventExtensions(object)方法可以改变这个行为,让你不能再给对象添加属性和方法。例如:$ R5 M1 @% C3 ^" ^3 C5 y( W
var person={name : 'jack'};
alert(Object.isExtensible(person));//true
Object.preventExtensions(person);
alert(Object.istExtensible(person));//false
2、密封的对象 2 g* V A5 R+ G D C+ x! n8 y' t ECMAScript 5 为对象定义的第二个保护级别是密封对象。使用Object.seal(object)方法可以将对象改为密封对象。密封对象不可扩展,而且已有成员的[[configurable]]特性将被设置为false。这就意味着不能删除属性和方法,因为不能使用Object.defineProperty()把数据修改为访问其属性,或者相反。但是属性值是可以修改的。 # m* t# v' O) g
var person = {name:'tom'};
alert(Object.isExtensible(person));///true,可扩展
alert(Object.isSealed(person));////false,未加密
Object.seal(person);
alert(Object.isExtensible(person));///false,不可扩展
alert(Object.isSealed(person));////true,已经加密
3、冻结的对象8 ?+ T0 A- i$ E; e3 p+ ~1 x
最严格的的防止篡改级别的是冻结对象,冻结的对象既不可扩展,又是密封的,而且对象的数据属性的[[Writable]]特性会被设置为false,如果定义set函数,访问器属性仍然是可写的,现在使用Object.freeze(object)方法可以将对象改为冻结的对象。 ' t) t4 \; a9 Y