加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

Object.create方法的用法是什么 原理怎样理解

发布时间:2023-06-27 13:40:17 所属栏目:语言 来源:
导读:这篇文章主要介绍“Object.create方法的用法是什么,原理如何理解”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Object.create方法的用法是什么,原理

这篇文章主要介绍“Object.create方法的用法是什么,原理如何理解”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Object.create方法的用法是什么,原理如何理解”文章能帮助大家解决问题。

ECMAScript 5 新增了 Object.create() 方法将原型式继承的概念规范化

用法

var obj = Object.create({name: 'johan', age: 23}) // obj 继承了属性name 和 age

var obj2 = Object.create(null) // obj2 不继承任何属性和方法

var obj3 = Object.create(Object.prototype) // 与 {} 和 new Object() 一个意思

var obj4 = Object.create({}, {

property1: {

value: true,

writable: true

}

}) // 第二个参数与 Object.defineProperties() 一致

图解 Object.create 实现

function create(proto) {

function F(){}

F.prototype = proto

return new F()

}

登录后复制

第一步: function F(){}

即创建一个函数,因为约定首字母大写,视为构造函数,创建函数 F 时,F 构造函数与和它的原型对象就有了这一层的关系:

F.prototype === F.prototype; // 假设你把F.prototype当作一个值

F.prototype.constructor === F;

登录后复制

第二步:F.prototype = proto

即将 F.prototype 赋值为传入的 proto,如此就打破了F.prototype = F.prototype 以及 F.prototype.constructor = F ,它们的关系为

第三步:return new F()

第三步的解读有点费解,因为这里涉及到 new 的操作,在 new 改变了对象 中我们说过,new 会创建一个对象,并将这个对象的隐式原型(__proto__) 指向构造函数的原型对象,并初始化构造函数,如果值则返回值。我们也会在后续的原型中介绍,new 是隐式原型继承,Object.create 是显式原型继承

在这里,我们按实现 new 的方式来解读 return new F()。new F 后的实例的 __proto__ 指向的是 F.prototype,而这个值已经在第二步时指给了传来的 proto,所以就有了new F().__proto__ = proto

或许你还是不太清楚第三步,我们结合例子,就一目了然了

var obj = Object.create({name: 'johan'})

登录后复制

第三步的图解就成了这样:

这样就成了, obj 继承自{name: johan} 这个对象,至于F.prototype = {name: 'johan'},在调用完 Object.create 之后,也因为没人使用 F 函数而被引擎当作垃圾回收了,遂成了obj.__proto__ = {name: 'johan'}

如此「原型式继承」就被传承下来了

其原理就是如此,简单来说,就是创建空(构造)函数,关联它的原型(实现继承)

Object.create(null)

登录后复制

在阅读源码时,常会看到 Object.create(null) ,用此初始化一个新对象,至于为什么用这个方法而不用 new Object 或者 {},是因为无论 new 还是字面量,都是继承自 Object 构造函数,而使用Object.create(null) ,能得到一个没有任何继承痕迹的对象

var obj = Object.create(null)

登录后复制

不信,你可以打印 obj 试试

以上就是关于“Object.create方法的用法是什么,原理如何理解”的介绍了,感谢各位的阅读。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!