混合函数继承方式构造函数

  混合继承方式使用构造函数定义类,并未使用任何原型。对象冒充的主要问题是必须使用构造函数方式,这不是最好的选择。不过如果使用原型链,就无法使用带参构造函数了。

  那么,我们该如何选择呢?

  答案很简单,两者都用。

  我们都知道创建类的最好方式是用构造函数方式定义属性,用原型方式定义方法。这种方法同样适用于继承机制,用对象冒充继承构造函数的属性,用原型链继承prototype对象的方法。例如:

  //基类:漂亮妹子,创建类的方法采用混合构造函数/原型方式

function Beauty(name){

  this.name = name;

Beauyt.prototype.say = function() {

  alert("我叫" + this.name);

 

//子类: 中国漂亮妹子,创建类的方法采用混合构造函数/原型方式

function Chian_beauty(name, area) {

  Beauty.call(this.name);          //用对象冒充继承构造函数的属性

  this.area = area;                   //扩展属性

}

 

China_beauty.prototype = new Beauty();            //继承方法

China_beauty.prototype.from = function() {        //用原型链继承prototype对象的方法

  alert("我来自" + this.area);

}

 

var beautygirl = new China_beauty("二丫", "四川");    //创建对象

beautygirl.say();  //调用函数

beautygirl.from();      //调用函数

转载于:https://www.cnblogs.com/LisaY/p/4748862.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值