`

js 抽象工厂模式B

 
阅读更多
// 接口
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 clone(object) {
	function F() {
	}
	F.prototype = object;
	return new F;
}

// 抽象工厂
var AbstractFactory = (function() {
	// 抽象方法检查
	function checkImplements(object) {
		var isContain = false;
		var v_method = '';
		if (arguments.length < 2) {
			throw new Error("Function AbstractFactory.checkImplements called with "
					+ arguments.length + "arguments, but expected at least 2.");
		}
		for (var i = 1; i < arguments.length; i++) {
			var v_AbstractClass = arguments[i];
			for (key in v_AbstractClass) {
				if (!object[key] && typeof object[key] !== 'function'
						&& key != 'getFactory') {
					isContain = true;
					v_method = key;
					break;
				}
			}
		}
		if (isContain) {
			throw new Error("Function AbstractFactory.ensureImplements: object "
					+ "does not implement the AbstractFactory "
					+ "AbstractCalss. AbstractMethod "
					+ v_method
					+ " was not found.");
		}
	}
	// 选择具体工厂
	function chooesFactory(mode) {
		var factory = null;
		switch (mode) {
			case 'giant' :
				factory = GiantFactory;
				break;
			case 'cnforever' :
				factory = CnforeverFactory;
				break;
			case 'merida' :
				factory = MeridaFactory;
				break;
			default :
				throw new Error("mode not found");
		}
		checkImplements(factory, AbstractFactory)
		return factory;
	}
	return {
		getFactory : function(mode) {
			return chooesFactory(mode);
		},
		// 抽象方法
		createBicycle : function() {
			throw new Error('Unsupported operation on an abstract class:createBicycle');
		}
	}
})();
// 继承
var GiantFactory = clone(AbstractFactory);
GiantFactory = {
	// 实现父类抽象方法
	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 bicycle = AbstractFactory.getFactory(mode).createBicycle();
		bicycle.assemble();
		bicycle.wash();;
		return bicycle;
	}
}

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

分享到:
评论

相关推荐

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

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

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

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

    Essential JavaScript Design Patterns

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

    JavaScript.Patterns

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

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

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

    商品展示网站

    在这个过程中,工厂模式帮助我们抽象出对象的创建过程,使得服务器能够根据不同的请求动态地创建相应的商品展示类实例。 系统的核心功能包括商品的展示、搜索和分类。商品信息的存储与管理是通过Oracle数据库实现的...

    Js-abstractions

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

    设计模式JavaScript

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

    抽象

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

    神路信息java面试题目

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

    模式

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

    000000000000000000000000000000000000000000000

    10)在.NET框架下,抽象工厂设计模式中,参与的对象包括抽象工厂(Abstract Factory)、实体工厂(Concrete Factory)、抽象产品(Abstract Product)和实体产品(Concrete Product)。选项e) 以上全部是正确的。 ...

    百度面试题汇总(java)

    17. **单例模式与抽象工厂模式**:单例模式确保一个类只有一个实例;抽象工厂模式提供一系列相关或相互依赖的对象接口。 18. **设计模式的应用场景**:例如工厂模式适用于创建多个相似对象的场景;策略模式适用于...

    Java笔试题

    3. 工厂模式是一种创建型设计模式,用于创建对象,而无需暴露创建逻辑,可以使用抽象工厂类或具体工厂类创建产品。 4. JSP是动态网页技术,Servlet是Java Web应用服务器端组件,两者可以结合使用,JSP更注重视图,...

    Reusable:可重用的抽象

    例如,单例模式确保一个类只有一个实例,工厂模式用于创建对象,观察者模式用于事件驱动的通信等。 5. **高阶函数与装饰器**:JavaScript中的高阶函数可以接收函数作为参数或返回函数,这样可以动态地组合和修改...

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

    6. 数据库移植设计模式:在.NET应用程序中,为了实现跨数据库平台的功能,通常采用抽象工厂设计模式。这种模式允许在运行时创建特定数据库的适配器,从而实现数据库无关性。 7. HTML DOM中的history对象:在DOM中,...

    经典求职简历及其他简历精选

    应聘者应该在简历中提到自己对MVC模式、Singleton、抽象工厂模式等面向对象设计模式的理解和应用能力,这些都是面试官评估应聘者软件设计能力的重要依据。 项目经验是简历中最为重要的部分之一。应聘者应该详细描述...

    underscore.multiplexer:当您希望函数接受单个参数集或多个参数集时! (考虑工厂功能)

    这在处理复杂函数工厂模式时特别有用。 多路复用器(Multiplexer,简写为`_.multiplexer`)是Underscore.js中一种强大的工具,它允许我们将多个函数组合成一个单一的函数。当我们有多个相似但又略有不同的函数需要...

Global site tag (gtag.js) - Google Analytics