o1.constructor = subType的作用何在?

发布于 2022-09-11 17:54:49 字数 973 浏览 26 评论 0

在了解js的寄生组合继承时看到了这篇博客 https://www.cnblogs.com/nullc...,对其中的一个地方不太理解。在这里粘贴一下求问:

寄生组合式继承:通过借用构造函数来继承属性,通过原型链的混成形式来继承方法.思路:不必为了指定子类的原型而调用父类的构造函数,我们所需要的无非就是父类原型的一个副本而已.本质上,就是使用寄生式继承来继承父类的原型,然后在将结果指定给子类的原型:

<script>
function inheritPrototype(subType,superType){
      var o1=Object.create(superType.prototype) ;        //创建父类原型的一个副本 
      o1.constructor = subType;                        //为副本添加constructor属性,弥补重写原型而失去的constructor属性
      subType.prototype=o1;                     //将创建的对象(副本)赋值给子类的原型
}
Object.create =  function(o){
    var F = function (){};
    F.prototype = o;
    return new F();
};
</script>

问题:
o1.constructor = subType的作用何在?
o1本质上是Object.create里的一个空的构造函数实例化出来的一个对象,所以o1是没有任何属性的,包括constructor属性,这一点理解,但是不理解为什么要使o1的constructor指向subType?如果说是修正constructor的指向的话,为什么不先写subType.prototype=o1再写o1.constructor = subType呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

我是男神闪亮亮 2022-09-18 17:54:49

可以先写subType.prototype=o1再写o1.constructor = subType;

这两条语句没有冲突,可以互换位置。

o1.constructor = subType的作用何在?这个是为了校正subType的constructor。因为subType.prototype=o1代码重写了subType的原型对象,这是的原型已经与最初的subType原型对象失去联系。

记住,在完全重写一个对象的原型对象时,最好重新指定constructor。不然子类的constructor属性就指向了超类,而不是子类。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文