JS设计模式之访问者模式

server/2024/12/18 12:47:42/

前言

访问者模式(Visitor Pattern)是一种 行为设计模式,它允许在不改变对象结构的情况下,定义新的操作。

这种模式通过将操作封装在访问者对象中,使得可以在不修改被访问对象的情况下,增加新的功能。

本文将详细介绍访问者模式的主要组成部分、工作原理、优点、缺点、应用场景,并提供一个简单的 JavaScript 代码示例。

主要组成部分

1、 访问者(Visitor):定义一个访问接口,声明对每个具体元素的访问方法。每个具体访问者实现这个接口,以提供对不同元素的具体操作。

2、 元素(Element):定义一个接受访问者的方法,通常是一个 accept 方法,接受一个访问者作为参数。

3、具体元素(Concrete Element):实现元素接口,定义具体的元素对象,并实现 accept 方法,调用访问者的相应方法。

4、 对象结构(Object Structure):维护一组元素,通常是一个集合,提供一个方法来接受访问者。

工作原理

1、 客户端创建一个访问者对象和一个对象结构。

2、 对象结构遍历其元素,并将访问者传递给每个元素的 accept 方法。

3、 每个元素调用访问者的相应方法,从而实现对元素的操作。

优点

开放/关闭原则:可以在不修改现有元素类的情况下,添加新的操作,符合开放/关闭原则。

集中操作:将操作集中在访问者中,便于管理和维护。

缺点

增加复杂性:引入访问者模式可能会增加系统的复杂性,特别是在元素类较多时。

不易扩展元素:如果需要添加新的元素类,必须修改所有访问者接口,可能导致代码的修改和维护成本增加。

应用场景

1、编译器和解释器:用于语法树的遍历。

2、对象结构的操作:对一组对象执行多种操作。

3、图形编辑器:对不同形状执行操作。

4、数据结构的遍历:在复杂的数据结构中遍历和操作节点。

5、报告生成:生成不同类型的报告。

6、对象的状态检查:对一组对象进行状态检查。

7、游戏开发:对游戏对象执行操作。

8、数据转换:将不同格式的数据转换为目标格式。

代码示例

javascript">// 访问者接口
class Visitor {  visitConcreteElementA(element) {  console.log(`Visiting ConcreteElementA: ${element.operationA()}`);  }  visitConcreteElementB(element) {  console.log(`Visiting ConcreteElementB: ${element.operationB()}`);  }  
}  // 元素接口
class Element {  accept(visitor) {}  
}  // 具体元素A
class ConcreteElementA extends Element {  accept(visitor) {  visitor.visitConcreteElementA(this);  }  operationA() {  return 'Operation A';  }  
}  // 具体元素B
class ConcreteElementB extends Element {  accept(visitor) {  visitor.visitConcreteElementB(this);  }  operationB() {  return 'Operation B';  }  
}  // 对象结构
class ObjectStructure {  constructor() {  this.elements = [];  }  addElement(element) {  this.elements.push(element);  }  accept(visitor) {  for (const element of this.elements) {  element.accept(visitor);  }  }  
}  // 使用访问者模式
const visitor = new Visitor();  
const objectStructure = new ObjectStructure();  objectStructure.addElement(new ConcreteElementA());  
objectStructure.addElement(new ConcreteElementB());  objectStructure.accept(visitor);

总结

访问者模式非常适合用于需要对一组对象执行多种操作的场景,尤其是在对象结构相对稳定,而操作频繁变化的情况下。

它提供了一种灵活的方式来管理操作,使得系统更加模块化和可维护。

通过将操作封装在访问者对象中,我们可以在不修改现有对象结构的情况下,轻松地添加新的操作,从而提高代码的可扩展性和可维护性。

– 欢迎点赞、关注、转发、收藏【我码玄黄】,各大平台同名。


http://www.ppmy.cn/server/151173.html

相关文章

AI、大数据、机器学习、深度学习、神经网络之间的关系

AI、大数据、机器学习、深度学习、神经网络之间的关系 一、人工智能(AI)的概念 人工智能是指通过计算机程序或机器来模拟、实现人类智能的技术和方法。它旨在使计算机具备感知、理解、判断、推理、学习、识别、生成、交互等类人智能的能力,…

React简单了解

原理简化了解 import React from "react" import { createRoot } form "react-dom/client"const element React.createElement(p,{id: hello},Hello World! )const container document.querySelector(#root) const root createRoot(container) root.r…

2024年全球安全光幕系统行业总体规模、主要企业国内外市场占有率及排名

根据QYResearch研究团队调研统计,2023年全球安全光幕系统市场销售额达到了 亿元,预计2030年将达到 亿元,年复合增长率(CAGR)为 %(2024-2030)。中国市场在过去几年变化较快,2023年市场…

数据结构漫游记:初识vector

​ 嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的…

数据结构-栈与队列

栈:一对一的线性储存结构,先进后出,只允许从一端进行数据的插入与删除的线性数据结构。用于,判断成对出现的东西,如判断回文字符串或者回文数,四则混合运算求值等。 顺序栈(数组)&a…

【学习记录】Docker初探(1)

系统:windows11 使用管理员打开cmd窗口,使用PowerShell wsl WSL 全称为 Windows Subsystem for Linux,即 Windows 上的 Linux 子系统。它是微软提供的一项功能,允许用户在 Windows 10 和 Windows 11 上直接运行 Linux 二进制可执…

深度比较:OpenNI2 SDK与Orbbec SDK的功能、优势和选择指南

深度比较:OpenNI2 SDK与Orbbec SDK的功能、优势和选择指南 为了全面地了解OpenNI2 SDK与Orbbec SDK以及选择适合您需求的SDK,我们需要深入分析这两个SDK的设计理念、功能特点、优势和局限性。以下是对两个SDK的详细、专业和有逻辑的比较分析。 OpenNI2…