TypeScript设计模式(4):装饰器模式

什么是装饰器模式?

装饰器模式 (Decorator Pattern) 是一种设计模式,允许在不修改原有类代码的前提下,通过装饰方式来扩展它的功能。在 TypeScript 中,我们可以利用装饰器函数来实现这一点。

装饰器模式的优点

  • 增量原有类的功能而不修改它的代码
  • 可以通过层层闭包来组合功能
  • 提高代码的重用性和可维护性

TypeScript 中装饰器的基本用法

TypeScript 支持使用 装饰器 (装饰器函数) 来扩展类、方法、属性和参数。装饰器实际上是一个函数,它可以将一个类或方法作为参数,并返回修改后的值。

简单例子

typescript 复制代码
function Logger(target: Function) {
  console.log(`类 ${target.name} 被创建`);
}

@Logger
class Person {
  constructor() {
    console.log("Person 实例创建");
  }
}

const p = new Person();

在此例子中, @Logger 装饰器会在 Person 类创建时被调用,它相当于对 Person 类进行了一次处理。

装饰器传递参数

typescript 复制代码
function WithTemplate(template: string, hookId: string) {
  return function (constructor: any) {
    const hookElement = document.getElementById(hookId);
    if (hookElement) {
      hookElement.innerHTML = template;
    }
  };
}

@WithTemplate("<h1>你好,TypeScript!</h1>", "app")
class App {}

这里的 WithTemplate 装饰器会将指定的 HTML 模板添加到 DOM 元素中。

方法装饰器

typescript 复制代码
function LogMethod(target: any, methodName: string, descriptor: PropertyDescriptor) {
  const originalMethod = descriptor.value;
  descriptor.value = function (...args: any[]) {
    console.log(`调用 ${methodName} 方法,参数:`, args);
    return originalMethod.apply(this, args);
  };
}

class Car {
  @LogMethod
  drive(speed: number) {
    console.log(`驾驶速度:${speed}`);
  }
}

const car = new Car();
car.drive(100);

这里的 @LogMethod 装饰器在每次调用 drive 方法时输出方法名和参数信息。

结论

装饰器模式是一种强大而很有用的模式,在 TypeScript 中,我们可以使用它来扩展类、方法和属性的功能而不需要修改源代码。这样能很好地提高代码的重用性和维护性。

相关推荐
lqqjuly19 小时前
设计模式:理论、架构与 C++ 实现—SOLID原则到23 种经典模式
c++·设计模式·架构
老码观察1 天前
设计模式实战解读(九):责任链模式——流水线上层层把关的艺术
java·设计模式·责任链模式
workflower3 天前
具身智能研究对象:物理交互中的智能行为
设计模式·动态规划·软件工程·软件构建·scrum
折哥的程序人生 · 物流技术专研3 天前
Java 23 种设计模式:从踩坑到精通 | 抽象工厂 —— 支付/收款如何成套创建?跨平台 UI 如何一键换肤?
java·开发语言·后端·设计模式
老码观察3 天前
设计模式实战解读(八):代理模式——控制访问的隐形中间层
设计模式·代理模式
我爱cope3 天前
【Agent智能体12 | 反思设计模式-使用外部反馈】
人工智能·设计模式·语言模型·职场和发展
geovindu3 天前
python: Bounded Parallelism Pattern
开发语言·python·设计模式·有界并行模式
我爱cope3 天前
【Agent智能体11 | 反思设计模式-评估反射的影响的方法】
人工智能·设计模式·语言模型·职场和发展
nnsix3 天前
设计模式 - 迭代器模式 笔记
笔记·设计模式·迭代器模式
geovindu3 天前
go: Bounded Parallelism Pattern
开发语言·后端·设计模式·golang·有界并行模式