Object.create(null) 和 {} 的区别

栏目: JavaScript · 发布时间: 7年前

内容简介:这两天在看vue的源码,发现作者定义映射字典的时候,喜欢用Object.create(null),而不是直接定义一个对象字面量,那么两者有什么区别呢,又存在什么业务场景呢for...in可以遍历n的原型属性试了一下发现没有打印toString\get\set方法属性,后来才发现混淆了两个概念,就是__proto__和prototype

这两天在看vue的源码,发现作者定义映射字典的时候,喜欢用Object.create(null),而不是直接定义一个对象字面量,那么两者有什么区别呢,又存在什么业务场景呢

let m = Object.create(null);
   let n = {};
   
   // 猜测下,m和n有什么区别呢
   console.log(m);
   console.log(n);
复制代码
Object.create(null) 和 {} 的区别

就是一个纯粹的空对象

Object.create(null) 和 {} 的区别

继承了对象原型的空对象,也就是说存在n.toString();

Object.create(proto, [propertiesObject]) 方法

  • proto 新建对象的原型对象
  • propertiesObject 可选,添加到新建对象的属性(不是原型链的属性),默认可枚举,参数对应Object.defineProperties的第二个参数

{} 相当于 Object.create(Object.ptototype), 现在你明白他们之间的区别了吧

for...in可以遍历n的原型属性

试了一下发现没有打印toString\get\set方法属性,后来才发现混淆了两个概念,就是__proto__和prototype

这个__proto__属性, 是一个对象的隐式原型,指向构造该对象的构造函数的原型

function A() {
       console.log('我是函数A')
   };
   let a = new A();
   console.log(a.__proto__ === A.prototype)  // true
复制代码

这个以后再做深入讨论。

ps。刚开始用md语法写文档,用的还不是很熟练,以后有更多跟有内含的文章给大家分享,加油加油!


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Computers and Intractability

Computers and Intractability

M R Garey、D S Johnson / W. H. Freeman / 1979-4-26 / GBP 53.99

This book's introduction features a humorous story of a man with a line of people behind him, who explains to his boss, "I can't find an efficient algorithm, but neither can all these famous people." ......一起来看看 《Computers and Intractability》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具