// 拷贝继承,在子类内调用父类并修正this指向,再通过for in 拷贝父类的方法实现继承,具体实现如下代码 :
function Tab(){//父类构造函数
this.name='aaa';
this.age=20;
}
Tab.prototype.init = function(){
alert(this.name);
};
function Child(){//子类构造函数
Tab.call(this);//在子类构造函数内调用父类,使子类继承父类的属性
}for(var attr in Tab.prototype){//通过for in 拷贝父类原型上的方法
Child.prototype[attr]=Tab.prototype[attr];
}
var child=new Child();
var tab=new Tab();
child.name="bbb";//这里我们修改了子类的属性,下面打印结果,修改了子类不会影响父类
console.log(tab)
console.log(child)console.log(child instanceof Tab);//false
console.log(child instanceof Child);//true 看出,child的构造函数还是自己本身
//原型继承,在子类的原型上继承父类的实例化对象 :
var father=function(){
this.name='aa';
}
father.prototype.a=function(){
alert(this.name);
}
var child=function(){}var fa=new father();
child.prototype=fa;//在子类的原型上继承父类这个对象
var man=new child();
man.name='bbb';
fa.name="ccc";
console.log(fa);
console.log(man);//继承的属性和值在其原型链上
alert(fa.name)//ccc
alert(man.name)//bbb//类式继承,通过在子类的构造函数类调用父类的构造函数,使子类拥有父类的属性和方法,并通过call或apply改变this指向,来实现继承 :
var father=function(){
this.name='aa';this.age=function(){alert(1)}
}
father.prototype.a=function(){
alert(this.name);
}
var child=function(){
father.call(this);
}child.prototype=father.prototype;//继承父类的方法
var f=new father();
var c=new child();
console.log(f);
console.log(c);
相关文章
- 深入浅出JavaScript之原型链&继承
- 对Javascript 类、原型链、继承的理解
- JavaScript 类式继承与原型继承
- JS面向对象组件 -- 继承的其他方式(类式继承、原型继承)
- js原生继承之——类式继承实例(推荐使用)
- JavaScript之面向对象学九(原型式继承和寄生式继承)
- c#实例化继承类,必须对被继承类的程序集做引用 .net core Redis分布式缓存客户端实现逻辑分析及示例demo 数据库笔记之索引和事务 centos 7下安装python 3.6笔记 你大波哥~ C#开源框架(转载) JSON C# Class Generator ---由json字符串生成C#实体类的工具
- 菜鸟快飞之JavaScript对象、原型、继承(一)
- JavaScript中的类式继承和原型式继承
- JavaScript 类式继承与原型继承