JS模式:又一个简单的工厂模式

<!DOCTYPE html>
<html>
<head>
    <title></title>
</head>
<body>
<script>
    function Car(options){
        this.doors = options.doors || 4;
        this.state = options.state || "brand new";
        this.color = options.color || "silver";
    };
    function Truck(options){
        this.state = options.state || "used";
        this.wheelSize = options.wheelSize || "large";
        this.color = options.color || "blue";
    };
    function VehicleFactory(){};
    VehicleFactory.prototype.vehicleClass = Car;
    VehicleFactory.prototype.createVehicle = function( options ){
        if(options.vehicleType == "car"){
            this.vehicleClass = Car;
        }else{
            this.vehicleClass = Truck;
        };
        return new this.createVehicle(options);
    };
    var carFactory = new VehicleFactory({
        vehicleType : 'truck',
        state : 'like new',
        color : 'red',
        wheelSize : 'small'
    });
    console.log( carFactory instanceof VehicleFactory);
    console.log( carFactory );

    function TruckFactory(){};
    TruckFactory.prototype = new VehicleFactory();
    TruckFactory.prototype.vehicleClass = 'truck';

    var truckFactory = new TruckFactory();
    console.log( truckFactory instanceof TruckFactory);
    
    //抽象 工厂模式---->_->
    var AbstractVehicleFactory = (function(){
        //定义车辆的类型,用来存储数据
        var types = {};
        return {
            registerVehicle : function(type,vehicle){
                types[type] = vehicle;
            },
            getVehicle : function(type,customizatoins){
                var vehicle = types[type];
                return (vehicle) ? new topics[type](customizations) : null;
            }
        }
    })();
</script>
</body>
</html>

 

转载于:https://www.cnblogs.com/diligenceday/p/3432441.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值