//原型冒充
function Cat(leg,tail) {
this.leg = 100;
this.tail = tail;
this.climb = function() {
alert('我会爬树');
}
}
function Tiger(leg,tail,color) {
//把要继承的类的语句,拿来执行一遍
this.parent = Cat;//把父类构造函数引入到一个parent属性上 parent属性只是一个普通属性,跟PHP中的parent含义是不一样的
this.leg = leg;
this.parent.apply(this,arguments);// 将tiger自身的形参传给cat类,并实例化
//delete this.parent;
this.color = color;
}
var tiger = new Tiger(4,1,'yellow');
console.log(tiger);
tiger.climb();//我会爬树
alert(tiger.leg);// 100
/*
以上的底层过程:
在用Tiger造对象时(即 var tiger = new Tiger());生成了一个空对象,但是在Tiger构造函数中,由于实例化了Cat对象,所以先由Cat构造函数影响了这个空对象,因此,最终得到的对象, 是由Cat和Tiger两者共同作用过的对象
留意:alert(tiger.leg)输出是100,因为先执行Tiger构造函数中的this.leg = leg赋值语句,然后下面再实例化Cat对象,实例化时,对leg的值做了修改
function Cat(leg,tail) {
this.leg = 100;
this.tail = tail;
this.climb = function() {
alert('我会爬树');
}
}
function Tiger(leg,tail,color) {
//把要继承的类的语句,拿来执行一遍
this.parent = Cat;//把父类构造函数引入到一个parent属性上 parent属性只是一个普通属性,跟PHP中的parent含义是不一样的
this.leg = leg;
this.parent.apply(this,arguments);// 将tiger自身的形参传给cat类,并实例化
//delete this.parent;
this.color = color;
}
var tiger = new Tiger(4,1,'yellow');
console.log(tiger);
tiger.climb();//我会爬树
alert(tiger.leg);// 100
/*
以上的底层过程:
在用Tiger造对象时(即 var tiger = new Tiger());生成了一个空对象,但是在Tiger构造函数中,由于实例化了Cat对象,所以先由Cat构造函数影响了这个空对象,因此,最终得到的对象, 是由Cat和Tiger两者共同作用过的对象
留意:alert(tiger.leg)输出是100,因为先执行Tiger构造函数中的this.leg = leg赋值语句,然后下面再实例化Cat对象,实例化时,对leg的值做了修改
*/
//赋值继承
function Cat(leg,tail) {
this.leg = leg;
this.tail = tail;
this.climb = function() {
alert('我会爬树');
}
}
function Tiger(color) {
this.color = color;
this.extend = function (parent) {
for(var key in parent) {
this[key] = parent[key];//将传送过来的对象赋值给自身
}
}
}
var tiger = new Tiger('yellwo');
//tiger.climb();//出错
tiger.extend(new Cat(4,1));
tiger.climb();
复制继承与继承的区别:
直接继承是形成原型链,如果链上的一个地方被修改,其他地方引用到这条链都会被影响到,但是如果使用复制继承就可以避免这种情况