javascript中的继承练习

/** 组合继承:使用原型链实现对原型属性和方法的继承,而通过借用构造函数来实现对实例属性的继承*/
function Person(name,age) {
    this.name = name;
    this.age = age;
}
Person.prototype.sayName = function(name){
    console.log("sayName:",name);
};

function Sun(name,age) {
    Person.call(this,name,age);
}
Sun.prototype = new Person();//此处没必要传入参数,因为这一步属于用原型链的方式来实现对原型属性和方法的继承。如果传入实参,
//就相当于给实例属性赋值了。
Sun.prototype.constructor = Sun;

var instance1 = new Sun("xiaoming",18);
console.log(instance1.age);
instance1.sayName(this.name);
var instance2 = new Sun("xiaohong",19);
console.log(instance2.age);



/** 构造方法中有参数,如果创建对象调用构造方法的时候没有传入实参,那么如下所示:对象的实例属性为undefine*/
/*function Job(job){
    this.name = job;
}
var job = new Job();
console.log(job.name);//undefined*/

/** 组合继承是javascript中最常用的继承方式,是将原型链和借用构造函数的技术结合到一起,
 *  借用构造函数的缺点是无法继承来自原型中的属性和方法,
 *  原型链的问题是原型来自实例,而实例中有实例属性,实例属性可能为引用类型,所以原型中可能存在引用类型的属性。原型中的引
 *  用类型可以被不同的实例共享,这就是问题所在。
 */























發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章