// 接口
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开发中是一种常用的创建对象的方式,...
抽象工厂模式提供了一个接口,用于创建一系列相关或相互依赖的对象,而无需指定它们具体的类。 ```javascript class AbstractFactory { createProductA() {} createProductB() {} } class ConcreteFactory1 ...
本文介绍了JavaScript中的一些常用设计模式,包括单例模式、工厂模式、抽象工厂模式、适配器模式、装饰者模式、策略模式以及观察者模式。通过这些设计模式的应用,可以有效地提高代码的质量和可维护性,同时也能够...
本文将简要介绍几种基础的设计模式:构造器模式、简单工厂模式、抽象工厂模式、单例模式以及原型模式。 1. **构造器模式**: 构造器模式是最基本的对象创建型模式,它允许我们在创建对象时初始化对象,为对象指定...
在这个过程中,工厂模式帮助我们抽象出对象的创建过程,使得服务器能够根据不同的请求动态地创建相应的商品展示类实例。 系统的核心功能包括商品的展示、搜索和分类。商品信息的存储与管理是通过Oracle数据库实现的...
JavaScript抽象是编程中的一个重要概念,它允许我们创建更高级别的逻辑,从而简化代码,提高可维护性和可重用性。在JavaScript中,抽象主要通过函数、模块、类和设计模式来实现。以下是对这些概念的详细说明: 1. *...
工厂模式提供了一种创建对象的抽象方法,隐藏了具体类的实例化过程。在JavaScript中,可以通过函数来实现工厂模式,根据传入的参数或条件返回不同类型的实例。 ```javascript function createShape(type) { if ...
例如,工厂模式用于创建对象,观察者模式用于事件驱动编程,装饰器模式用于动态地添加或修改对象的行为。 通过以上各种抽象方式,JavaScript程序员能够构建出复杂的系统,同时保持代码的清晰和简洁。理解并熟练运用...
工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式,通过抽象工厂类或者具体工厂类来生产实例,降低了代码间的耦合。 8. **软件开发流程** 软件开发通常遵循以下步骤: - 需求分析:明确项目目标,...
2. 工厂模式:创建对象的抽象方法,不直接暴露对象的实例,而是返回一个与输入参数相关联的对象。 ```javascript function createObject(type) { let obj; if (type === 'TypeA') { obj = new TypeA(); } else ...
10)在.NET框架下,抽象工厂设计模式中,参与的对象包括抽象工厂(Abstract Factory)、实体工厂(Concrete Factory)、抽象产品(Abstract Product)和实体产品(Concrete Product)。选项e) 以上全部是正确的。 ...
17. **单例模式与抽象工厂模式**:单例模式确保一个类只有一个实例;抽象工厂模式提供一系列相关或相互依赖的对象接口。 18. **设计模式的应用场景**:例如工厂模式适用于创建多个相似对象的场景;策略模式适用于...
3. 工厂模式是一种创建型设计模式,用于创建对象,而无需暴露创建逻辑,可以使用抽象工厂类或具体工厂类创建产品。 4. JSP是动态网页技术,Servlet是Java Web应用服务器端组件,两者可以结合使用,JSP更注重视图,...
例如,单例模式确保一个类只有一个实例,工厂模式用于创建对象,观察者模式用于事件驱动的通信等。 5. **高阶函数与装饰器**:JavaScript中的高阶函数可以接收函数作为参数或返回函数,这样可以动态地组合和修改...
6. 数据库移植设计模式:在.NET应用程序中,为了实现跨数据库平台的功能,通常采用抽象工厂设计模式。这种模式允许在运行时创建特定数据库的适配器,从而实现数据库无关性。 7. HTML DOM中的history对象:在DOM中,...
应聘者应该在简历中提到自己对MVC模式、Singleton、抽象工厂模式等面向对象设计模式的理解和应用能力,这些都是面试官评估应聘者软件设计能力的重要依据。 项目经验是简历中最为重要的部分之一。应聘者应该详细描述...
这在处理复杂函数工厂模式时特别有用。 多路复用器(Multiplexer,简写为`_.multiplexer`)是Underscore.js中一种强大的工具,它允许我们将多个函数组合成一个单一的函数。当我们有多个相似但又略有不同的函数需要...