本文给大家介绍有关ecmascript 5中 新增的object.create() 方法,对于不了解的同学,欢迎收藏学习哟~
ecmascript 5 新增了 object.create() 方法将原型式继承的概念规范化【推荐学习:javascript视频教程】
用法
var obj = object.create({name: 'johan', age: 23}) // obj 继承了属性name 和 agevar 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 试试
以上就是图解js中的object.create方法(附代码实例)的详细内容。
