码迷,mamicode.com
首页 > Web开发 > 详细

JS继承

时间:2017-07-02 10:06:47      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:ons   argument   create   object   原型链   重复   sub   接收   最好   

1. 单个继承
Object.create(Proto [,propertiesObject]);  // 使用指定的原型对象和属性创建一个新对象。

2.原型链方式

因为有可能重写或添加子类型的方法,为了保证之后创建的所有子类型都继承同一个超类型,一定要在创建新实例之前修改原型对象。

  子类型构造函数.prototype=超类型的实例;

注意:

  通过原型链实现的继承,不能使用对象字面量创建原型方法,因为这样会重写原型链。

  不能向超类型的构造函数中传递参数。

  如果原型被重写,最好同时修改原型的constructor属性。

  如果超类型的属性中有引用类型值,所有实例共享一个属性,不好

3. 组合继承

(1)在子类型构造函数内部用call/apply调用父类型的构造函数。

注意:arguments指SubType接收到的所有参数,SupType从0位开始按顺序读取。所以SubType构造函数的参数中前面是SupType的参数,之后才是SubType用到的参数(SubType能够用标识符识别参数的值,而SupType只能通过位序使用)。

(2)将父类型的实例赋值给子类型的原型,继承父类共享的属性和方法。

注意:组合继承会两次调用父类构造函数,在子类实例和原型中会有重复的属性。

4.寄生式组合继承

通过借用构造函数来继承属性,通过原型链的混合形式来继承方法。不必为了指定子类型的原型而调用超类型的构造函数,只需父类型的原型副本。

//使用指定的原型对象创建一个新的空对象作为中间体,类似于Object.create() 方法

JS继承

标签:ons   argument   create   object   原型链   重复   sub   接收   最好   

原文地址:http://www.cnblogs.com/liuqr/p/7104169.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!