模板设计模式在Js中的使用

模板设计模式

定义

模板模式是一种行为型设计模式,它定义了一个算法的骨架,并允许子类在不改变算法结构的情况下重写算法中的某些步骤。

参与者

  1. 抽象类(Abstract Class):抽象类定义了模板方法,该方法包含了算法的骨架,其中的具体步骤可能由子类实现。抽象类也可以提供一些默认的实现,以便子类选择性地覆盖。

  2. 具体类(Concrete Class):具体类是抽象类的子类,它实现了抽象类中定义的具体步骤。每个具体类都可以根据需要实现自己的逻辑,但不能改变算法的结构。

原理

在模板模式中,算法的骨架被定义在抽象类中的模板方法中,该方法按照固定的顺序调用了一系列的具体步骤。其中的一些步骤可能在抽象类中提供了默认的实现,但也可以由具体类进行覆盖。通过这种方式,模板模式使得算法的整体结构保持稳定,但允许具体步骤的灵活替换。

优点

在于它提供了一种标准化的算法结构,使得不同的子类可以共享和重用相同的骨架代码。它还能够将变化部分隔离在具体类中,使得算法的修改更加灵活。

应用场景

模板模式常用于以下情况:当多个类有相似的算法,但某些步骤可能有所不同,

或者希望定义一个算法的整体结构,但允许部分步骤由子类来实现时,模板模式是一种很好的选择。

例如,在编写web框架时,可以使用模板模式来定义通用的请求处理流程,但允许具体的处理细节由不同的控制器进行实现。

示例

typescript 复制代码
class AbstractClass {

  templateMethod() {

    this.primitiveOperation1();

    this.primitiveOperation2();

  }

  


  abstract primitiveOperation1(): void;

  abstract primitiveOperation1(): void;

}

  


class ConcreteClassA extends AbstractClass {

  primitiveOperation1() {

    console.log("ConcreteClassA: Step 1");

  }

  


  primitiveOperation2() {

    console.log("ConcreteClassA: Step 2");

  }

}

  


class ConcreteClassB extends AbstractClass {

  primitiveOperation1() {

    console.log("ConcreteClassB: Step 1");

  }

  


  primitiveOperation2() {

    console.log("ConcreteClassB: Step 2");

  }

}

  


const classA = new ConcreteClassA();

classA.templateMethod(); // 输出:ConcreteClassA: Step 1, ConcreteClassA: Step 2

  


const classB = new ConcreteClassB();

classB.templateMethod(); // 输出:ConcreteClassB: Step 1, ConcreteClassB: Step 2

感性理解

在ts中,我实现一个抽象类S,此抽象类具有方法A和抽象方法B C,如果A中使用了B和C且保证S被继承的时候A不会被重写,则这样就实现了模板设计模式。

原生实现

  1. JavaScript 中的 Array.prototype.sort() 方法:这个方法使用了模板设计模式来实现排序算法。它定义了一个模板方法 compareFunction,该方法接受两个参数并返回一个比较结果。具体的排序逻辑由 compareFunction 方法的实现决定,可以根据需要进行自定义。

  2. 浏览器中的事件处理程序(Event Handlers):例如,当我们为某个元素绑定点击事件时,可以使用模板设计模式来定义事件处理程序。在事件处理函数中,可以预先定义一些通用的操作步骤,然后调用具体的事件处理逻辑。

  3. JavaScript 中的模块加载器(如 RequireJS、CommonJS):这些模块加载器使用模板设计模式来定义加载和注入模块的过程。它们提供了一种标准化的模块加载流程,但允许开发人员在特定的模块中实现自己的逻辑。

  4. XMLHttpRequest 对象:在使用 XMLHttpRequest 发送 AJAX 请求时,可以通过使用回调函数来实现模板设计模式。我们可以定义一个模板方法,在其中指定 AJAX 请求的一般流程和处理逻辑,然后在具体的回调函数中实现特定的业务逻辑。

业务场景

见【感性理解】部分。事实上在平时的工作中,会不经意的实现模板设计模式,这种设计模式用的还是比较多的!

总结

模板设计模式在原生 JavaScript 和浏览器中的应用比较广泛。它允许我们定义算法的整体结构,并在特定的地方留出可自定义的空间,以适应不同的需求。通过这种方式,我们可以提高代码的复用性、可维护性和可扩展性。

相关推荐
geovindu32 分钟前
go: Mediator Pattern
设计模式·golang·中介者模式
云水一下4 小时前
从零开始!VMware安装Fedora Workstation 44桌面系统完整教程
前端
小码哥_常5 小时前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd5 小时前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码16 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen6 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦6 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen6 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
不会敲代码16 小时前
从零搭建 AI 日记助手:用 Milvus 向量数据库实现语义搜索
javascript·openai
千寻girling6 小时前
《 Git 详细教程 》
前端·后端·面试