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语法写文档,用的还不是很熟练,以后有更多跟有内含的文章给大家分享,加油加油!


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

查看所有标签

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

编程卓越之道

编程卓越之道

Hyde R / 韩东海 / 电子工业出版社 / 2006-4-1 / 49.80

各位程序员一定希望自己编写的代码是能让老板赞赏、满意的代码;是能让客户乐意掏钱购买的代码;是能让使用者顺利使用的代码;是能让同行欣赏赞誉的代码;是能让自己引以为豪的卓越代码。本书作者为希望能编写出卓越代码的人提供了自己积累的关于卓越编程的真知灼见。它弥补了计算机科学和工程课程中被忽略的一个部分——底层细节,而这正是构建卓越代码的基石。具体内容包括:计算机数据表示法,二进制数学运算与位运算,内存组织......一起来看看 《编程卓越之道》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

SHA 加密
SHA 加密

SHA 加密工具