`

js 抽象工厂模式A

 
阅读更多
var Interface = function(name, methods) {
	if (arguments.length != 2) {
		throw new Error("Interface constructor called with " + arguments.length
				+ "arguments, but expected exactly 2.");
	}

	this.name = name;
	this.methods = [];
	for (var i = 0, len = methods.length; i < len; i++) {
		if (typeof methods[i] !== 'string') {
			throw new Error("Interface constructor expects method names to be "
					+ "passed in as a string.");
		}
		this.methods.push(methods[i]);
	}
};
Interface.ensureImplements = function(object) {
	if (arguments.length < 2) {
		throw new Error("Function Interface.ensureImplements called with "
				+ arguments.length + "arguments, but expected at least 2.");
	}

	for (var i = 1, len = arguments.length; i < len; i++) {
		var v_interface = arguments[i];
		if (v_interface.constructor !== Interface) {
			throw new Error("Function Interface.ensureImplements expects arguments "
					+ "two and above to be instances of Interface.");
		}

		for (var j = 0, methodsLen = v_interface.methods.length; j < methodsLen; j++) {
			var method = v_interface.methods[j];
			if (!object[method] || typeof object[method] !== 'function') {
				throw new Error("Function Interface.ensureImplements: object "
						+ "does not implement the " + v_interface.name
						+ " interface. Method " + method + " was not found.");
			}
		}
	}
};

function extend(subClass, superClass) {
	var F = function() {
	};
	F.prototype = superClass.prototype;
	subClass.prototype = new F();
	subClass.prototype.constructor = subClass;

	subClass.superclass = superClass.prototype;
	if (superClass.prototype.constructor == Object.prototype.constructor) {
		superClass.prototype.constructor = superClass;
	}
}

var AbstractFactory = function() {
};
AbstractFactory.prototype = {
	chooesFactory : function(mode) {
		var factory = null;
		switch (mode) {
			case 'giant' :
				factory = new GiantFactory();
				break;
			case 'cnforever' :
				factory = new CnforeverFactory();
				break;
			case 'merida' :
				factory = new MeridaFactory();
				break;
			default :
				throw new Error("mode not found");
		}
		return factory;
	},
	createBicycle : function() {
		throw new Error('Unsupported operation on an abstract class:createBicycle');
	}
};
var GiantFactory = function() {
};
extend(GiantFactory, AbstractFactory);
GiantFactory.prototype = {
	createBicycle : function() {
		var giantBicycle = new GiantBicycle();
		Interface.ensureImplements(giantBicycle, Bicycle);
		return giantBicycle;
	}
};
var Bicycle = new Interface("Bicycle", ['assemble', 'wash', 'ride', 'repair']);
var GiantBicycle = function() {

};
GiantBicycle.prototype = {
	assemble : function() {
		alert('清洗');
	},
	wash : function() {
		alert('组装');
	},
	ride : function() {

	},
	repair : function() {

	}
};

var BicycleShop = function() {
};
BicycleShop.prototype = {
	sellBicycle : function(mode) {
		var abstractFactory = new AbstractFactory();
		var factory = abstractFactory.chooesFactory(mode);
		var bicycle = factory.createBicycle();
		bicycle.assemble();
		bicycle.wash();;
		return bicycle;
	}
}

var bicycleShop = new BicycleShop();
bicycleShop.sellBicycle('giant');

分享到:
评论

相关推荐

    抽象工厂模式-多多数据.rar_C#_C# webBrowser_CefSharp_blink_blink内核

    抽象工厂模式是一种设计模式,属于创建型模式,它提供了一种创建对象族的接口,而无需指定具体的类。在C#编程中,这种模式经常被用来处理不同平台或环境下的对象创建问题,例如在本例中,我们看到的是C#中的Web...

    JavaScript面向对象实现简单工厂模式

    简单工厂模式的核心思想是将对象的创建过程抽象出来,由一个专门的工厂类负责,使得客户端代码无需关心具体对象的实例化过程,只需要通过调用工厂的方法就能得到所需的对象。 在JavaScript中,由于其语言特性,没有...

    js代码-设计模式之工厂模式--简单工厂模式

    然而,缺点是如果产品类型过多,工厂类可能会变得过于复杂,且不易于维护,此时可能需要考虑使用更高级的设计模式,如抽象工厂模式或策略模式。 总之,简单工厂模式在JavaScript开发中是一种常用的创建对象的方式,...

    js代码-工厂模式demo

    JavaScript中的工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。在工厂模式中,当创建对象时,我们不会对构造函数进行调用,而是调用一个工厂函数来生产对象。这样做可以隐藏对象创建的复杂性,并...

    23中设计模式学习汇总

    - **定义**:抽象工厂模式提供了一个接口,用于创建一系列相关或相互依赖的对象,而无需指定它们具体的类。 - **意图**: - 提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。 - 通过这个...

    Javascript Design Patterns

    抽象工厂模式提供了一个接口用于创建一系列相关或相互依赖的对象,而无需指定它们具体的类。在JavaScript中,可以通过组合工厂模式和接口实现: ```javascript class GUIFactory { createButton() {} createInput...

    Essential JavaScript Design Patterns

    抽象工厂模式提供了一个接口,用于创建一系列相关或相互依赖的对象,而无需指定它们具体的类。 ```javascript class AbstractFactory { createProductA() {} createProductB() {} } class ConcreteFactory1 ...

    0A办公软件毕业项目

    这个项目采用了先进的软件工程设计理念,包括分层架构、抽象工厂模式、数据库访问类以及Ajax技术,实现了业务逻辑、数据访问和用户界面的三层分离,确保了系统的可维护性和扩展性。 1. 分层架构:分层架构是软件...

    javascript 经典面向对象设计

    - 抽象工厂模式 - 建造者模式 - 适配器模式 - 装饰器模式 - 代理模式 - 观察者模式 - 策略模式 - 桥接模式 - 组合模式 - 状态模式 - 访问者模式 4. **模块化与包管理** - 模块的概念 - AMD/CMD/ES6 ...

    JavaScript.Patterns

    本文介绍了JavaScript中的一些常用设计模式,包括单例模式、工厂模式、抽象工厂模式、适配器模式、装饰者模式、策略模式以及观察者模式。通过这些设计模式的应用,可以有效地提高代码的质量和可维护性,同时也能够...

    简单过过Javascript设计模式(上)

    本文将简要介绍几种基础的设计模式:构造器模式、简单工厂模式、抽象工厂模式、单例模式以及原型模式。 1. **构造器模式**: 构造器模式是最基本的对象创建型模式,它允许我们在创建对象时初始化对象,为对象指定...

    基于Java的实例源码-通用数据底层 Jsa4j.zip

    "Jsa4j"中的“Jsa”可能是“Java数据抽象”或“Java系统接入”的缩写,而“4j”可能表示它完全用Java编写,强调其与Java生态系统的紧密集成。 【Java数据处理】 在Java中,数据处理通常涉及到集合框架、数据库连接...

    Js-abstractions

    JavaScript抽象是编程中的一个重要概念,它允许我们创建更高级别的逻辑,从而简化代码,提高可维护性和可重用性。在JavaScript中,抽象主要通过函数、模块、类和设计模式来实现。以下是对这些概念的详细说明: 1. *...

    抽象

    例如,工厂模式用于创建对象,观察者模式用于事件驱动编程,装饰器模式用于动态地添加或修改对象的行为。 通过以上各种抽象方式,JavaScript程序员能够构建出复杂的系统,同时保持代码的清晰和简洁。理解并熟练运用...

    000000000000000000000000000000000000000000

    2. **抽象工厂设计模式**:在 .NET 框架下,抽象工厂设计模式主要用于创建一系列相关或相互依赖的对象,而无需指定它们的具体类。在这个模式中,抽象工厂(abstract factory)定义了创建产品对象的接口,实体工厂...

    TypeScript.zip

    2. 工厂模式:工厂模式提供了一种创建对象的方式,隐藏了对象创建的细节。在TypeScript中,可以通过抽象工厂类或函数来实现: ```typescript interface Shape { draw(): void; } class Circle implements Shape {...

    设计模式JavaScript

    工厂模式提供了一种创建对象的抽象方法,隐藏了具体类的实例化过程。在JavaScript中,可以通过函数来实现工厂模式,根据传入的参数或条件返回不同类型的实例。 ```javascript function createShape(type) { if ...

    神路信息java面试题目

    工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式,通过抽象工厂类或者具体工厂类来生产实例,降低了代码间的耦合。 8. **软件开发流程** 软件开发通常遵循以下步骤: - 需求分析:明确项目目标,...

    北大青鸟S2复习题(6) ACCP5.0

    14. **抽象工厂设计模式**:在.NET框架下的应用程序中,抽象工厂设计模式提供了一种创建对象家族的方式,其主要功能是创建相关或依赖对象的家族,而无需指定具体类。这个模式在实现时,通常包括创建不同类型的对象,...

    模式

    2. 工厂模式:创建对象的抽象方法,不直接暴露对象的实例,而是返回一个与输入参数相关联的对象。 ```javascript function createObject(type) { let obj; if (type === 'TypeA') { obj = new TypeA(); } else ...

Global site tag (gtag.js) - Google Analytics