Object.freeze和Object.seal的区别

Object.freeze()

官方MDN对Object.freeze()的说明,如下:

Object.freeze()方法可以冻结一个对象。

一个被冻结的对象再也不能被修改;冻结了一个对象则不能向这个对象添加新的属性,不能删除已有属性,不能修改该对象已有属性的可枚举性、可配置性、可写性,以及不能修改已有属性的值。此外,冻结一个对象后该对象的原型也不能被修改。

freeze() 返回和传入的参数相同的对象。

Object.freeze()做了哪些事情?

  1. 设置Object.preventExtension(),禁止添加新属性(绝对存在)
  2. 设置writable为false,禁止修改(绝对存在)
  3. 设置configurable为false,禁止配置(绝对存在)
  4. 禁止更改访问器属性(getter和setter)

从上可知,Object.freeze()禁止了所有可设置的内容。

另外,可以使用Object.isFrozen()判断一个对象是否是冻结对象。

Object.freeze()只是浅冻结

Object.seal()

官方MDN对Object.seal()的说明,如下:

Object.seal()方法封闭一个对象,阻止添加新属性并将所有现有属性标记为不可配置。

当前属性的值只要可写就可以改变。

Object.seal()做了哪些事情?

  1. 设置Object.preventExtension(),禁止添加新属性(绝对存在)
  2. 设置configurable为false,禁止配置(绝对存在)
  3. 禁止更改访问器属性(getter和setter)

另外,可以使用Object.isSealed()判断一个对象是否是封闭对象。

注意设置configurable为false会起到如下作用:

1、不可以通过delete去删除该属性从而重新定义属性;
2、不可以转化为访问器属性;
3、configurable和enumerable不可被修改;
4、writable可单向修改为false,但不可以由false改为true;
5、value是否可修改根据writable而定。

对比Object.freeze()和Object.seal()

使用Object.freeze()冻结的对象中的现有属性是不可变的。

用Object.seal()密封的对象可以改变其现有属性。

Object.preventExtensions()

官方MDN对Object.preventExtensions()的说明,如下:

Object.preventExtensions()方法让一个对象变的不可扩展,也就是永远不能再添加新的属性

另外,可以使用Object.isExtensible()判断一个对象是否可扩展。

//空对象是特殊情况,设置Object.preventExtensions()后,以下情况都将被禁止:

var empty = {};

Object.preventExtensions(empty);
Object.isFrozen(empty) === true
Object.isSealed(empty) === true
Object.isExtensible(empty) === false

https://blog.csdn.net/flitrue/article/details/103565803

posted @ 2021-04-13 10:22  Hhhighway  阅读(212)  评论(0编辑  收藏  举报