js继承(借助中间类)
var extendFn=(()=>{
const F=function(){} // 中间类
return function (Origin,Target){
F.prototype=Origin.prototype; // 只能继承Origin的prototype的属性 不能继承 Origin 的属性
// F.prototype=new Origin(); //既可以继承其prototype的属性 也可以继承 自己的属性(如果父类的属性比较复杂 创建实例会非常消耗性能)
Target.prototype= new F();
Target.prototype.constuctor = Target; // 让construtor指向自己
Target.prototype.uber=Origin; // 继承的源类
}
})()
// 例子
let Obj=function (){
this.grade='高二';
}
Obj.prototype.age='12'
let obj= new Obj();
let Tag=function (){}
extendFn(Obj,Tag)
let tag = new Tag();
console.log(tag.age) // 12
console.log(tag.agrade // a是Obj自己的属性所以是 undefined