object.create(null) 和 {}创建对象的区别

Posted shcrk

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了object.create(null) 和 {}创建对象的区别相关的知识,希望对你有一定的参考价值。

原文

  简书原文:https://www.jianshu.com/p/43ce4d7d6151

创建对象的方法

  如果要创建一个空的对象,可以使用如下的三种方法

var obj1 = {};
var obj2 = Object.create(null);
var obj3 = new Object();

创建空对象的区别

  要创建一个干净的空对象,应该使用Object.create(null)而不是剩下两种。
  通过做Objist.create(NULL),我们显式指定NULL作为它的原型。所以它绝对没有属性,甚至没有构造函数、toString、hasOwnProperty属性,所以如果需要的话,可以在数据结构中使用这些键,而不需要通过hasOwnProperty进行判断。

var obj1 = {};
var obj2 = Object.create(null);
var obj3 = new Object();

var con1 = obj1.constructor;
var con2 = obj2.constructor;
var con3 = obj3.constructor;

console.log(con1);//? Object() { [native code] }
console.log(con2);//undefined
console.log(con3);// Object() { [native code] }

实例说明

const dirtyMap = {};
const cleanMap = Object.create(null);
const key;
for(key in dirtyMap){
  // Check to avoid iterating over inherited properties.
  //不纯净的对象是需要做判断的
  if (dirtyMap.hasOwnProperty(key)) {   
    console.log(key + " -> " + dirtyMap[key]);
  }
}

for(key in cleanMap){
  // No need to add extra checks, as the object will always be clean
  //纯净的对象不需要做判断
  console.log(key + " -> " + cleanMap[key]);    
}

  

 


以上是关于object.create(null) 和 {}创建对象的区别的主要内容,如果未能解决你的问题,请参考以下文章

Object.create(null)Object.create({}){} 三者创建对象的区别

Object.create(null)

Object.create(null)的解释

Object.create(null)的解释

jslint:如何抑制'预期的'Object.create(null)',而是看到'新对象'。警告?

在 Chrome(V8) 中 Symbol() Object.create(null) 和 {} 的内存占用分别是多少?