javaScript设计模式---(工厂模式学习)

Posted RunningAndRunning

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javaScript设计模式---(工厂模式学习)相关的知识,希望对你有一定的参考价值。

工厂模式(Factory)提供一个公用的接口来创建对象。

如有一个UI库,我们要创建某个UI组件的类型,不需要直接使用new 运算符或者通过另一个创建型构造函数创建这个组件,而是要求Factory对象创建一个新的组件。我们通知Factory需要什么样的对象(如按钮、面板),它会进行实例化,然后将它返回给我们。

function Car (name, color) {
    this.name = name;
    this.color = color;
}
function Trunk (name, color) {
    this.name = name;
    this.color = color;
}
function vehicleFactory () {
}
vehicleFactory.prototype.vehicleClass = Car; // 添加默认类型
vehicleFactory.prototype.createVehicle = function (name, color) {
    if (name === ‘car‘) {
        this.vehicleClass = Car;
    } else {
        this.vehicleClass = Trunk;
    }
    return new vehicleClass(name, color);
}
let factory = new vehicleFactory()
let car = factory.createVehicle(‘car‘, ‘red‘)
console.log(car instanceof Car) // true
let trunk = factory.createVehicle(‘trunk‘, ‘blank‘)
console.log(trunk instanceof Trunk) // true

 

以上是关于javaScript设计模式---(工厂模式学习)的主要内容,如果未能解决你的问题,请参考以下文章

Javascript设计模式之工厂模式

JavaScript 创建对象 (工厂模式构造函数模式原型模式组合使用构造函数模式与原型模式)

设计模式简单工厂之我见

JavaScript学习总结--创建对象

JavaScript 常见的设计模式

JavaScript 常见的设计模式