结合原型链继承和call继承的方法,同时自己创建一个对象,并且让这个对象的原型指向父类构造函数的prototype.实现寄生组合继承。
function Parent(x) { this.x = x this.Hello = function () { } } Parent.prototype.getx = function () { console.log('getx ===>', this.x); } function Sub(y) { this.y = y Parent.call(this, 100) } //方法一 // let obj = {}; //obj.__proto__ = Parent.prototype //因为IE浏览器不支持用户在js中直接使用或者修改__proto__ //Sub.prototype = obj //方法二 Sub.prototype = Object.create(Parent.prototype) //方法一和方法二的效果一样但建议使用方法二因为IE浏览器不支持用户在js中直接使用或者修改__proto__; //所以可以使用Object.create()方法来实现这个效果。 //Object.create() ---> 创建一个空的对象,并且让这个空对象的__proto__指向传递的第一个参数 Sub.prototype.constructor = Sub Sub.prototype.gety = function () { console.log('gety ===>', this.y); } let sub = new Sub(200) console.log(sub);
、
1.最完美的js继承解决方案
2.父类私有的属性和方法,成为子类实例私有的属性和方法
3.父类公有的属性和方法,成为子类实例公有的属性和方法