【设计模式】之抽象工厂模式

简介: 抽象工厂模式是一种创建型设计模式,适用于需要创建一系列相关或相互依赖对象的场景。在前端开发中,抽象工厂模式可以帮助我们更好地组织和管理代码,提高代码的可维护性和可扩展性。它通过封装对象的创建过程,使得客户端代码与具体类解耦,并且可以通过切换具体工厂类来改变整个系统的行为。然而,它也增加了系统的复杂度,并且当产品族较多时会导致大量的具体工厂类。因此,在使用抽象工厂模式时需要权衡利弊,并根据实际情况进行选择。

✨ 专栏介绍

设计模式是在软件开发中经过验证的解决问题的方法。它们是从经验中总结出来的,可以帮助我们更好地组织和管理代码,提高代码的可维护性、可扩展性和可重用性。无论是前端还是后端开发,设计模式都扮演着重要的角色。在本专栏中,我们将探索一些常见的前端设计模式,并学习如何将它们应用于实际项目中。通过掌握这些设计模式,我们可以编写更优雅、可靠且易于维护的前端代码。

image.png

本文主要讲解创建型模式中的抽象工厂模式


抽象工厂模式是一种创建型设计模式,它提供了一种创建一系列相关或相互依赖对象的接口,而无需指定具体类。在前端开发中,抽象工厂模式可以帮助我们更好地组织和管理代码,提高代码的可维护性和可扩展性。


抽象工厂模式特性

  1. 抽象工厂模式将对象的创建与使用分离,客户端只需要关心接口而不需要关心具体实现。
  2. 抽象工厂模式可以通过切换具体工厂类来改变整个系统的行为。
  3. 抽象工厂模式符合开闭原则,当需要增加新的产品族时,只需要扩展抽象工厂和具体工厂类即可。


应用示例

1. 创建一个UI组件库:

// 抽象工厂classUIComponentFactory {
createButton() {}
createInput() {}
}
// 具体工厂classMaterialUIComponentFactoryextendsUIComponentFactory {
createButton() {
returnnewMaterialButton();
  }
createInput() {
returnnewMaterialInput();
  }
}
classAntDesignUIComponentFactoryextendsUIComponentFactory {
createButton() {
returnnewAntDesignButton();
  }
createInput() {
returnnewAntDesignInput();
  }
}
// 抽象产品classButton {}
classInput {}
// 具体产品classMaterialButtonextendsButton {}
classMaterialInputextendsInput {}
classAntDesignButtonextendsButton {}
classAntDesignInputextendsInput {}
// 使用constmaterialFactory=newMaterialUIComponentFactory();
constmaterialButton=materialFactory.createButton();
constmaterialInput=materialFactory.createInput();
constantDesignFactory=newAntDesignUIComponentFactory();
constantDesignButton=antDesignFactory.createButton();
constantDesignInput=antDesignFactory.createInput();
  1. UIComponentFactory 类是一个抽象的工厂类,它定义了两个基本的工厂方法:createButton()createInput()。这些方法在具体的工厂类中被覆盖,以创建特定类型的按钮和输入框。
  2. MaterialUIComponentFactoryAntDesignUIComponentFactory 是两个具体的工厂类,它们继承自 UIComponentFactory。每个工厂都有自己的 createButton()createInput() 方法,这些方法返回特定类型的按钮和输入框(分别是 MaterialButtonMaterialInput,以及 AntDesignButtonAntDesignInput)。
  3. ButtonInput 是抽象产品类,它们定义了产品的一般性特征。具体的 MaterialButtonAntDesignButton 类继承自 Button 类,而 MaterialInputAntDesignInput 类继承自 Input 类。

最后创建了两个具体的工厂对象(materialFactoryantDesignFactory),并使用它们的 createButton()createInput() 方法创建了具体的按钮和输入框对象。


2. 创建一个跨浏览器的XHR对象

// 抽象工厂classXHRFactory {
createXHR() {
returnnewXHR();
  }
}
// 具体工厂classStandardXHRFactoryextendsXHRFactory {
createXHR() {
returnnewStandardXHR();
  }
}
classActiveXHRFactoryextendsXHRFactory {
createXHR() {
returnnewActiveXHR();
  }
}
// 抽象产品classXHR {
send(data) {
thrownewError("This method must be overridden");
  }
}
// 具体产品classStandardXHRextendsXHR {
send(data) {
console.log("Sending data with StandardXHR: "+data);
  }
}
classActiveXHRextendsXHR {
send(data) {
console.log("Sending data with ActiveXHR: "+data);
  }
}
// 使用letxhr;
if (newXMLHttpRequest()) {
conststandardXhrFactory=newStandardXHRFactory();
xhr=standardXhrFactory.createXHR();
} elseif (newActiveXObject()) {
constactiveXhrFactory=newActiveXHRFactory();
xhr=activeXhrFactory.createXHR();
} else {
thrownewError("No suitable XHR implementation found");
}
if (xhrinstanceofStandardXHR) {
xhr.send("Some data");
} elseif (xhrinstanceofActiveXHR) {
xhr.send("Some data");
} else {
thrownewError("Unknown XHR type");
}


首先,我们定义了一个抽象工厂类XHRFactory,其中包含一个createXHR()方法用于创建XHR对象。


然后,我们定义了两个具体工厂类StandardXHRFactoryActiveXHRFactory,它们分别继承自抽象工厂类,并实现了createXHR()方法来创建具体的XHR对象。


接着,我们定义了一个抽象产品类XHR,其中包含一个抽象方法send(data)。然后,我们定义了两个具体产品类StandardXHRActiveXHR,它们分别继承自抽象产品类,并实现了send(data)方法来发送数据。


在使用部分,我们首先通过判断浏览器是否支持XMLHttpRequest来选择具体的工厂类。如果支持,则使用StandardXHRFactory创建一个标准的XHR对象;如果不支持,则使用ActiveXHRFactory创建一个ActiveX的XHR对象。然后,根据具体的XHR对象类型来调用相应的发送数据方法。

这样,在不同浏览器环境下,我们可以通过抽象工厂模式来创建适合当前环境的跨浏览器的XHR对象,并且可以统一调用发送数据方法。

优缺点

优点

  1. 提供了一种封装对象创建的方式,使得客户端代码与具体类解耦,易于维护和扩展。
  2. 可以通过切换具体工厂类来改变整个系统的行为,提高代码的灵活性和可配置性。
  3. 符合开闭原则,当需要增加新的产品族时,只需要扩展抽象工厂和具体工厂类即可。

缺点

  1. 增加了系统的复杂度,引入了更多的类和接口。
  2. 当产品族较多时,需要创建大量的具体工厂类,增加了代码量。

总结

抽象工厂模式是一种创建型设计模式,适用于需要创建一系列相关或相互依赖对象的场景。在前端开发中,抽象工厂模式可以帮助我们更好地组织和管理代码,提高代码的可维护性和可扩展性。它通过封装对象的创建过程,使得客户端代码与具体类解耦,并且可以通过切换具体工厂类来改变整个系统的行为。然而,它也增加了系统的复杂度,并且当产品族较多时会导致大量的具体工厂类。因此,在使用抽象工厂模式时需要权衡利弊,并根据实际情况进行选择。



目录
相关文章
|
6月前
|
设计模式 C++
设计模式之抽象工厂模式(C++)
设计模式之抽象工厂模式(C++)
|
6月前
|
设计模式
设计模式~抽象工厂模式-04
抽象工厂 优点 缺点 使用场景 为创建一组相
29 0
|
4月前
|
设计模式 Java
Java设计模式【三】:抽象工厂模式
Java设计模式【三】:抽象工厂模式
21 0
|
7天前
|
设计模式 Java
【设计模式系列笔记】抽象工厂模式
抽象工厂模式(Abstract Factory Pattern)是一种设计模式,属于创建型模式之一。它提供了一种方式来创建一系列相关或相互依赖的对象,而无需指定它们具体的类。抽象工厂模式通过引入抽象的工厂接口,使得客户端代码可以使用抽象的接口来创建一组相关的产品,而不关心这些产品的具体实现。
103 4
|
7月前
|
设计模式
设计模式~~~抽象工厂模式
设计模式~~~抽象工厂模式
29 0
|
24天前
|
设计模式 Java Windows
23种设计模式,抽象工厂模式的概念优缺点以及JAVA代码举例
【4月更文挑战第10天】抽象工厂模式是一种创建型设计模式,它提供了一个接口用于创建相关或依赖对象的家族,而不需要指定具体类。该模式允许客户端在不知道具体类的情况下,通过其共同的接口来创建一组产品。
29 7
|
3月前
|
设计模式 Oracle 关系型数据库
设计模式 | 抽象工厂模式
设计模式 | 抽象工厂模式
25 0
|
3月前
|
设计模式 Go 开发工具
Golang设计模式——02抽象工厂模式
Golang设计模式——02抽象工厂模式
23 0
|
8月前
|
设计模式 Java 数据库连接
Java设计模式之抽象工厂模式:创造多个相关对象
在软件开发领域,设计模式是一种用于解决常见问题的实践方法,它提供了一些被验证过的指导原则。抽象工厂模式是创建型设计模式中的佼佼者,可以帮助我们在处理多个相关对象的创建时保持一致性。让我们深入了解抽象工厂模式的内涵以及它如何在Java中应用。
61 0
|
3月前
|
设计模式 NoSQL 中间件
设计模式 - 创建型模式_抽象工厂模式
设计模式 - 创建型模式_抽象工厂模式
23 0