显示混入:
function mixin(sourceObj, targetObj){for(var key in sourceObj){ // 遍历source中的所有属性if(!(key in targetObj)) { // 找到targetz中没有的属性targetObj[key] = sourceObj[key];}}return targetObj;
}var Vehicle = {engines: 1,iginition: function() {console.log("Turning on my engine.");},drive: function(){this.ignition();console.log("Steering an moving forward!" );}
};var Car = mixin( Vehicle, {wheels: 4,drive: function() {Vehicle.drive.call( this);console.log(" Rolling on all " + this.wheels + " wheels!");}
});
寄生继承:
// 既是显式的又是隐式的
function Vehicle() {this.engines = 1;
}
Vehicle.prototype.iginition = function() {console.log("Turning on my engine.");
}
Vehicle.prototype.drive = function() {this.ignition();console.log("Steering and moving forward!");
};// "寄生类"Car
function Car(){var car = new Vehicle();car.wheels = 4;var vehDrive = car.drive;car.drive = function(){vehDrive.call(this);console.log("Rolling on all" + this.wheels + "wheels!);}return car;
}
var myCar = new Car();myCar.drive();// Turning on my engine.
// Steering and moving forward!
// Rolling on all 4 wheels!
隐式混入:
var Something = {cool: function() {this.greeting = "Hello World";this.count = this.count ? this.count + 1: 1; // 存在count,次数加1,否则初始值为1}
};
Something.coll();
Something.greeeting = "Hello World";
Something.count = 1;var Another = {cool: function() {Something.cool.call(this); // 执行Something.cool,作用域是Another的}
};
Another.cool();
Another.greeting = "Hello World";
Another.count = 1; // 注.Another.count 和 Something.count不共享状态.
参考《你不直到的JavaScript》(上卷) P135~P140