Object.seal()与Object.freeze()
作者:互联网
// 1.禁止扩展 // 如果你想禁止一个对象添加新属性并且保留已有属性 // 可以使用 Object.preventExtensions(..) var myObj = {a:2}; Object.preventExtensions( myObj ); myObj.b = 3; myObj.b; // undefined var a = {b: {c:123}, d: 234}; Object.seal(a); a.b.f = 456 a;//{b: {c: 123, f: 456}, d: 234}; //说明只会prevent一级属性Extentsion //注意:在非严格模式下,创建属性b会静默失败 //在严格模式下,将会抛出 TypeError 错误 // 2.密封 // Object.seal(..) // 会创建一个"密封"的对象,这个方法实际上会在一个现有对象上调用 // Object.preventExtensions(..) // 并把所有现有属性标记为configurable:false // 所以,密封之后不仅不能添加新属性,也不能重新配置或者删除任何现有属性 // (虽然可以 修改属性的值) // 3.冻结 Object.freeze(..) 会创建一个冻结对象, // 这个方法实际上会在一个现有对象上调用 Object.seal(..) // 并把所有"数据访问"属性标记为 writable:false,这样就无法修改它们 的值。 // 这个方法是你可以应用在对象上的级别最高的不可变性, // 它会禁止对于对象本身及其任意 // 直接属性的修改(不过就像我们之前说过的,这个对象引用的其他对象是不受影响的) // 你可以"深度冻结"一个对象,具体方法为, // 首先在这个对象上调用 Object.freeze(..), // 然后遍历它引用的所有对象并在这些对象上调用 Object.freeze(..)。 // 但是一定要小心,因 为这样做有可能会在无意中冻结其他(共享)对象。
标签:..,对象,Object,freeze,seal,属性 来源: https://www.cnblogs.com/pittle-z/p/14070707.html