【前端设计模式】之工厂模式
工厂模式特性
工厂模式是一种创建对象的设计模式,它通过使用工厂类来封装对象的创建逻辑,隐藏了具体对象的实例化过程。工厂模式的主要特性包括:
- 封装对象的创建过程:工厂模式将对象的创建过程封装在一个工厂类中,客户端只需要通过调用工厂类的方法来获取所需的对象,而无需关心具体的实例化过程。
- 提供统一的接口:工厂模式通常会定义一个统一的接口或基类,所有由工厂创建的对象都实现该接口或继承该基类,使得客户端可以统一对待不同类型的对象。
- 可扩展性:通过添加新的具体产品类和对应的具体工厂类,可以方便地扩展系统中可以创建的对象类型。
前端应用示例
在前端开发中,常见使用工厂模式来创建不同类型的组件、插件或者服务。以下是一个简单示例:
// 定义产品接口
class Product {constructor(name) {this.name = name;}getName() {return this.name;}
}// 定义具体产品类
class ConcreteProductA extends Product {constructor() {super('Product A');}
}class ConcreteProductB extends Product {constructor() {super('Product B');}
}// 定义工厂类
class Factory {createProduct(type) {switch (type) {case 'A':return new ConcreteProductA();case 'B':return new ConcreteProductB();default:throw new Error('Invalid product type.');}}
}// 使用示例
const factory = new Factory();
const productA = factory.createProduct('A');
console.log(productA.getName()); // Output: "Product A"const productB = factory.createProduct('B');
console.log(productB.getName()); // Output: "Product B"
在上面的示例中,我们首先定义了一个产品接口Product
,并实现了两个具体产品类ConcreteProductA
和ConcreteProductB
。然后,我们定义了一个工厂类Factory
,其中的createProduct
方法根据传入的参数类型来创建对应的产品对象。
1. UI组件库
在前端开发中,我们经常会使用UI组件库来构建用户界面。工厂模式可以用来创建不同类型的UI组件,例如按钮、表单、对话框等。通过使用工厂模式,我们可以将具体的组件创建逻辑封装在工厂类中,使得客户端代码与具体组件类解耦。
// 定义按钮组件接口
class Button {render() {// 渲染按钮}
}// 定义具体按钮组件类
class PrimaryButton extends Button {render() {// 渲染主要按钮样式}
}class SecondaryButton extends Button {render() {// 渲染次要按钮样式}
}// 定义按钮工厂类
class ButtonFactory {createButton(type) {switch (type) {case 'primary':return new PrimaryButton();case 'secondary':return new SecondaryButton();default:throw new Error('Invalid button type.');}}
}// 使用示例
const buttonFactory = new ButtonFactory();
const primaryButton = buttonFactory.createButton('primary');
primaryButton.render(); // 渲染主要按钮样式const secondaryButton = buttonFactory.createButton('secondary');
secondaryButton.render(); // 渲染次要按钮样式
2. 数据请求库
工厂模式可以用来创建不同类型的数据请求对象,例如基于XMLHttpRequest的Ajax请求、基于Fetch API的请求等。通过使用工厂模式,我们可以根据不同的需求选择合适的数据请求对象,并统一对待不同类型的请求。
// 定义数据请求接口
class DataRequest {send(url, options) {// 发送数据请求并返回结果}
}// 定义具体数据请求类(基于XMLHttpRequest)
class XHRRequest extends DataRequest {send(url, options) {// 使用XMLHttpRequest发送请求并返回结果}
}// 定义具体数据请求类(基于Fetch API)
class FetchRequest extends DataRequest {send(url, options) {// 使用Fetch API发送请求并返回结果}
}// 定义数据请求工厂类
class DataRequestFactory {createRequest(type) {switch (type) {case 'xhr':return new XHRRequest();case 'fetch':return new FetchRequest();default:throw new Error('Invalid request type.');}}
}// 使用示例
const requestFactory = new DataRequestFactory();
const xhrRequest = requestFactory.createRequest('xhr');
xhrRequest.send(' https://api.example.com/data ', { method: 'GET' });const fetchRequest = requestFactory.createRequest('fetch');
fetchRequest.send(' https://api.example.com/data ', { method: 'GET' });
3. 插件系统
工厂模式可以用来创建插件对象,并提供统一的接口供客户端使用。通过使用工厂模式,我们可以方便地添加新的插件,并统一管理和调用插件。
// 定义插件接口
class Plugin {init() {// 初始化插件}
}// 定义具体插件类
class AnalyticsPlugin extends Plugin {init() {// 初始化统计插件}
}class LoggerPlugin extends Plugin {init() {// 初始化日志插件}
}// 定义插件工厂类
class PluginFactory {createPlugin(type) {switch (type) {case 'analytics':return new AnalyticsPlugin();case 'logger':return new LoggerPlugin();default:throw new Error('Invalid plugin type.');}}
}// 使用示例
const pluginFactory = new PluginFactory();
const analyticsPlugin = pluginFactory.createPlugin('analytics');
analyticsPlugin.init(); // 初始化统计插件const loggerPlugin = pluginFactory.createPlugin('logger');
loggerPlugin.init(); // 初始化日志插件
4. 路由管理器
在单页应用(SPA)开发中,路由管理器负责根据URL路径加载对应的页面或组件。工厂模式可以用来创建路由对象,并根据不同的URL路径返回对应的页面或组件。通过使用工厂模式,我们可以方便地扩展路由规则,并统一管理路由逻辑。
// 定义路由接口
class Router {navigate(url) {// 根据URL导航到对应的页面或组件}
}// 定义具体路由类
class HashRouter extends Router {navigate(url) {// 使用哈希路由导航到对应的页面或组件}
}class HistoryRouter extends Router {navigate(url) {// 使用历史路由导航到对应的页面或组件}
}// 定义路由工厂类
class RouterFactory {createRouter(type) {switch (type) {case 'hash':return new HashRouter();case 'history':return new HistoryRouter();default:throw new Error('Invalid router type.');}}
}// 使用示例
const routerFactory = new RouterFactory();
const hashRouter = routerFactory.createRouter('hash');
hashRouter.navigate('/home'); // 根据哈希路由导航到首页const historyRouter = routerFactory.createRouter('history');
historyRouter.navigate('/about'); // 根据历史路由导航到关于页面
这些示例展示了工厂模式在不同场景下的应用,通过使用工厂模式,我们可以封装对象的创建逻辑,提高代码的可维护性和可扩展性。同时,工厂模式还可以提供统一的接口或基类,使得客户端可以统一对待不同类型的对象。
优缺点
优点
- 将对象的创建逻辑封装在工厂类中,使得客户端代码与具体产品类解耦,提高了代码的可维护性和可扩展性。
- 可以通过添加新的具体产品类和对应的具体工厂类来扩展系统中可以创建的对象类型。
- 提供统一的接口或基类,使得客户端可以统一对待不同类型的对象。
缺点
- 增加了系统中的类数量,增加了代码复杂度。
- 对于简单对象创建逻辑而言,引入工厂模式可能会增加不必要的复杂性。
总结
工厂模式是一种常用的创建对象的设计模式,它通过封装对象的创建逻辑,提供统一的接口,实现了代码的解耦和可扩展性。在实际开发中,可以根据具体需求选择是否使用工厂模式来创建对象。工厂模式可以应用于任何需要创建对象的场景。通过使用工厂模式,我们可以提高代码的可维护性、可扩展性和可测试性,使得代码更加灵活和易于理解。
相关文章:
【前端设计模式】之工厂模式
工厂模式特性 工厂模式是一种创建对象的设计模式,它通过使用工厂类来封装对象的创建逻辑,隐藏了具体对象的实例化过程。工厂模式的主要特性包括: 封装对象的创建过程:工厂模式将对象的创建过程封装在一个工厂类中,客…...

Hive 的函数介绍
目录 编辑 一、内置运算符 1.1 关系运算符 1.2算术运算符 1.3逻辑运算符 1.4复杂类型函数 1.5对复杂类型函数操作 二、内置函数 2.1数学函数 2.2收集函数 2.3类型转换函数 2.4日期函数 2.5条件函数 2.6字符函数 三、内置的聚合函数 四、内置表生成函数 五、…...

【Linux基础】第31讲 Linux用户和用户组权限控制命令(三)
用户组管理命令 每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同。如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。用户组的管理涉及用户组的添加、删除和修改。组…...

html form表单高级用法
场景:想单纯使用表单内置的api完成提交,不使用js代码 代码如下: <form name"myForm" action"http://localhost:13734/form" method"post"><label>用户名<input type"text" name&qu…...
openssl升级
参考 https://www.cnblogs.com/shareHistory/p/15850707.html 下载并安装依赖 wget https://www.openssl.org/source/openssl-3.0.5.tar.gz yum -y install perl-IPC-Cmd编译安装 ./config -Wl,-rpath/usr/local/openssl/lib -fPIC --prefix/usr/local/openssl --openssldir…...

【数据结构】图的遍历:广度优先(BFS),深度优先(DFS)
目录 1、广度优先(BFS) 算法思想 广度优先生成树 知识树 代码实现 2、深度优先(DFS) 算法思想 深度优先生成树 知识树 代码实现 1、广度优先(BFS) 算法思想 图的广度优先遍历࿰…...
Mysql 学习总结(89)—— Mysql 库表容量统计
前言 统计每个库每个表的大小是数据治理中最简单的一个要求,下面从抽样统计结果及精确统计结果两方面来统计MySQL的每个库每个表的数据量情况。mysql 数据字典库 information_schema 里记录了统计的预估数据量(innodb 引擎表不准确,MyISAM 引擎表准确)及数据大小、索引大小及…...

virtualBox安装配置使用
virtualBox下载 //官网下载地址 https://www.virtualbox.org/wiki/Downloads //ubuntu下载地址 https://cn.ubuntu.com/download/server/step1 virtualBox使用 导入现有镜像 (如果报错可以降低系统配置,因为有些主机可能不支持高配置,例如…...

北斗导航 | RTD、RTK完好性之B值、VPL与HPL计算(附B值计算matlab源代码)
===================================================== github:https://github.com/MichaelBeechan CSDN:https://blog.csdn.net/u011344545 ===================================================== 1、S矩阵获取 为第i颗卫星测距标准差:...
more often than not 的含义
今天听https://www.bilibili.com/video/BV1w94y12727/?p2&spm_id_frompageDriver more often than not 连读:mor ofen than au 想了半天不动什么意思. 查了一下表示大部分情况下. 还是不理解为什么, 就查了必应里面的词典. 表示超过一半的情况下. 又自己想了想突然懂了.…...

【Linux】Linux环境配置安装
目录 一、双系统(特别不推荐) 安装双系统的缺点: 安装双系统优点(仅限老手): 二、虚拟机centos7镜像(较为推荐推荐) 虚拟机的优点: 虚拟机的缺点: …...

从零学习开发一个RISC-V操作系统(二)丨GCC编译器和ELF格式
本篇文章的内容 一、GCC(GUN Compiler Collection)1.1 GCC的命令格式1.2 GCC的主要执行步骤1.3 GCC涉及的文件类型 二、ELF简介2.1 ELF文件格式图2.2 ELF文件处理的相关工具2.3 练习 本系列是博主参考B站课程学习开发一个RISC-V的操作系统的学习笔记&…...

论文阅读_大语言模型_Llama2
英文名称: Llama 2: Open Foundation and Fine-Tuned Chat Models 中文名称: Llama 2:开源的基础模型和微调的聊天模型 文章: http://arxiv.org/abs/2307.09288 代码: https://github.com/facebookresearch/llama 作者: Hugo Touvron 日期: 2023-07-19 引用次数: 11…...

当量因子法、InVEST、SolVES模型等多技术融合在生态系统服务功能社会价值评估中的应用及论文写作、拓展分析
生态系统服务是人类从自然界中获得的直接或间接惠益,可分为供给服务、文化服务、调节服务和支持服务4类,对提升人类福祉具有重大意义,且被视为连接社会与生态系统的桥梁。自从启动千年生态系统评估项目(Millennium Ecosystem Asse…...
k8s Limits 限制内存
Limits 限制内存 在 Kubernetes (K8s) 中,可以使用 Limits(资源限制)来限制 Pod(容器)使用的内存数量。此处的 Limits 表示 Pod 在 K8s 集群中可用的最大内存量。一旦 Pod 内存使用超过这个限制,可能会触发…...

单片机第三季-第三课:STM32开发板原理图、配置、浮点运算单元
目录 1,开发板原理图 2,浮点运算单元(FPU) 1,开发板原理图 课程视频比较早,介绍了三款开发板。观看视频时用的开发板说和51单片机共板的STM32核心板,将51单片机从底座拆下来后,安…...
观察者模式 发布-订阅模式(设计模式与开发实践 P8)
文章目录 观察者模式运用实现 观察者模式 定义:他用来定义对象之间一种一对多的依赖关系,当一个对象状态发生改变时,所有依赖他的对象都会得到通知 运用 如果我们使用过 DOM 上的事件函数,那就接触过观察者模式 document.body…...

【日常业务开发】Java实现异步编程
【日常业务开发】Java实现异步编程 Java实现异步编程什么是异步异步的八种实现方式异步编程线程异步Future异步CompletableFuture实现异步Spring的Async异步Spring ApplicationEvent事件实现异步消息队列ThreadUtil异步工具类Guava异步 CompletableFuture异步编排工具类创建异步…...

学习笔记|模数转换器|ADC原理|STC32G单片机视频开发教程(冲哥)|第十七集:ADC采集
文章目录 1.模数转换器(ADC)是什么?手册说明: 2.STC32G单片机ADC使用原理19.1.1 ADC控制寄存器(ADC_CONTR)19.1.2 ADC配置寄存器(ADCCFG)19.1.4ADC时序控制寄存器(ADCTIM)19.3 ADC相…...

OpenCV实现“蓝线挑战“特效
原理 算法原理可以分为三个流程: 1、将视频(图像)从(顶->底)或(左->右)逐行(列)扫描图像。 2、将扫描完成的行(列)像素重新生成定格图像…...

SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...

大话软工笔记—需求分析概述
需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...

UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...

Python爬虫(一):爬虫伪装
一、网站防爬机制概述 在当今互联网环境中,具有一定规模或盈利性质的网站几乎都实施了各种防爬措施。这些措施主要分为两大类: 身份验证机制:直接将未经授权的爬虫阻挡在外反爬技术体系:通过各种技术手段增加爬虫获取数据的难度…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...

SiFli 52把Imagie图片,Font字体资源放在指定位置,编译成指定img.bin和font.bin的问题
分区配置 (ptab.json) img 属性介绍: img 属性指定分区存放的 image 名称,指定的 image 名称必须是当前工程生成的 binary 。 如果 binary 有多个文件,则以 proj_name:binary_name 格式指定文件名, proj_name 为工程 名&…...

回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...
C++.OpenGL (14/64)多光源(Multiple Lights)
多光源(Multiple Lights) 多光源渲染技术概览 #mermaid-svg-3L5e5gGn76TNh7Lq {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-3L5e5gGn76TNh7Lq .error-icon{fill:#552222;}#mermaid-svg-3L5e5gGn76TNh7Lq .erro…...