zoukankan      html  css  js  c++  java
  • js继承精益求精之寄生式组合继承

    一、混合/组合继承的不足

      上一篇JS继承终于混合继承,认真思考一下,发现其还是有不足之处的:

    空间上的冗余:在使用原型链的方法继承父类的原型属性(Animal.prototype)的同时,也在子类的原型(Person.prototype)中继承多了一份父类属性(Animal.property);具体来说:p与p.prototype中都保存了type,children,而p.prototype这一份是冗余的;

    二、寄生式组合继承

      为了解决上面的问题,所以需要在混合继承的基础上进行改造。那么如何避免冗余呢?

    • 避免使用 Person.prototype = new Animal() 来继承整个Animal实例;
    • 这样将代码改写为 Person.prototype = Animal.prototype
    • 那么又会引入一个问题,Person.prototype与Animal.prototype共用一个空间(在正常继承中,Person.prototype应该有自己独立的空间),也就是说一旦我们修改了Person.prototype,同时也修改了Animal.prototype;
    • 所以继续修改代码为 Person.prototype=Object.create(Animal.prototype)
      下图为Object.create的实现(在支持ES5的浏览器中可以直接使用);
      最后一句修改为:return new F();
      函数中返回的F即为Person.prototype的独立空间
    • 完美主义者,constructor的指向问题(改不改都不影响):原来返回的F.constructor指向Animal,要修改为指向Person;

  • 相关阅读:
    yum和apt-get用法及区别
    Vim终极指南:所思即所得
    Vim 操作符命令和动作命令
    vim中文手册
    标准代码页(codepage)列表
    中文字符集编码Unicode ,gb2312 , cp936 ,GBK,GB18030
    vim在系统剪切板的复制与粘贴
    linux中高亮显示文本的工具 -- bat
    pandas category数据类型
    pandas 数据类型转换
  • 原文地址:https://www.cnblogs.com/jiahuix/p/4723989.html
Copyright © 2011-2022 走看看