18--26 面向对象程序设计25(继承的三种方式)

来源:互联网 发布:云端软件 编辑:程序博客网 时间:2024/06/07 16:43

转载请注明出处:http://blog.csdn.net/u011569040/article/details/50987573

// 原型继承//原型继承的特点:即继承了父类的模版,又继承了 父类的原型对象// 父类function Person(name, age){this.name = name ; this.age  = age ;}// 父类的原型对象属性Person.prototype.id = 10 ;// 子类function Boy(sex){this.sex = sex ; }//继承已经实现了 Boy.prototype = new Person('z3');var b = new Boy();alert(b.name);alert(b.id);
但是我们习惯于这样:new Boy(“zhngdan”)就传参,而不是new Person(“z3”)时传参


// 类继承(只继承模版,不继承原型对象) (借用构造函数的方式继承)// 父类function Person(name, age){this.name = name ; this.age  = age ;}// 父类的原型对象属性Person.prototype.id = 10 ;// 子类function Boy(name , age , sex){// call applyPerson.call(this,name,age);this.sex = sex ; }var b = new Boy('张三' , 20 , '男');//alert(b.name);//alert(b.age);//alert(b.sex);//alert(b.id); //父类的原型对象并没有继承

但是id没有被继承,即原型属性没有被继承,所以:

// 原型继承+借用构造函数继承 = 混合继承// 父类function Person(name, age){this.name = name ; this.age  = age ;}// 父类的原型对象属性Person.prototype.id = 10 ;Person.prototype.sayName = function(){alert(this.name);};// 子类function Boy(name , age , sex){// call applyPerson.call(this,name,age); // 1 借用构造函数继承 继承父类的模版this.sex = sex ; }// 2 原型继承// 只剩下 父类的实例 和 父类的原型对象的关系了Boy.prototype = new Person(); //继承父类的原型对象var b = new Boy('李四' , 20 , '男');alert(b.name);alert(b.sex);b.sayName();



0 0
原创粉丝点击