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























  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值