设计模式 - 命令模式

使用命令模式 ,可以将执行特定任务的对象与调用该方法的对象分离。假设有一个在线送餐平台。用户可以下订单、跟踪订单和取消订单。

javascript 复制代码
class OrderManager() {
  constructor() {
    this.orders = []
  }

  placeOrder(order, id) {
    this.orders.push(id)
    return `You have successfully ordered ${order} (${id})`;
  }

  trackOrder(id) {
    return `Your order ${id} will arrive in 20 minutes.`
  }

  cancelOrder(id) {
    this.orders = this.orders.filter(order => order.id !== id)
    return `You have canceled your order ${id}`
  }
}

OrderManager 类上,可以访问 placeOrdertrackOrdercancelOrder 方法。直接使用这些方法将是完全有效的 JavaScript!

javascript 复制代码
const manager = new OrderManager();

manager.placeOrder("Pad Thai", "1234");
manager.trackOrder("1234");
manager.cancelOrder("1234");

但是,直接在manager实例上调用这些方法也有缺点。以后可能会决定重命名某些方法,或者方法的功能发生变化。

假设现在不将其命名为 placeOrder,而是将其重命名为 addOrder!这意味着必须确保不会在代码库中的任何位置调用 placeOrder 方法,这在大型应用程序中可能非常棘手。相反,希望将方法与 manager 对象分离,并为每个命令创建单独的命令函数!

让我们重构 OrderManager 类:它不再有 placeOrdercancelOrdertrackOrder 方法,而是只有一个方法:execute。此方法将执行它给出的任何命令。

每个命令都应该有权访问管理器orders,我们将将其作为其第一个参数传递。

javascript 复制代码
class OrderManager {
  constructor() {
    this.orders = [];
  }

  execute(command, ...args) {
    return command.execute(this.orders, ...args);
  }
}

这里需要为订单管理器创建三个Command

  • PlaceOrderCommand
  • CancelOrderCommand
  • TrackOrderCommand
javascript 复制代码
class Command {
  constructor(execute) {
    this.execute = execute;
  }
}

function PlaceOrderCommand(order, id) {
  return new Command((orders) => {
    orders.push(id);
    return `You have successfully ordered ${order} (${id})`;
  });
}

function CancelOrderCommand(id) {
  return new Command((orders) => {
    orders = orders.filter((order) => order.id !== id);
    return `You have canceled your order ${id}`;
  });
}

function TrackOrderCommand(id) {
  return new Command(() => `Your order ${id} will arrive in 20 minutes.`);
}

完善!这些方法不再是直接耦合到 OrderManager 实例,而是单独的解耦函数,我们可以通过 OrderManager 上可用的 execute 方法调用它们。

优点

命令模式允许我们将方法与执行操作的对象解耦。如果您正在处理具有一定生命周期的命令,或者应该在特定时间排队和执行的命令,那么它可以使您获得更大的控制权。

缺点

命令模式的使用情况相当有限,并且经常为应用程序添加不必要的样板代码。

相关推荐
q***188413 小时前
SpringDoc和Swagger使用
命令模式
佛祖让我来巡山18 小时前
设计模式深度解析:策略模式、责任链模式与模板模式
设计模式·责任链模式·策略模式·模版模式
__万波__20 小时前
二十三种设计模式(三)--抽象工厂模式
java·设计模式·抽象工厂模式
转转技术团队20 小时前
VDOM 编年史
前端·设计模式·前端框架
明洞日记1 天前
【设计模式手册014】解释器模式 - 语言解释的优雅实现
java·设计模式·解释器模式
ZHE|张恒1 天前
设计模式(十六)迭代器模式 — 统一访问集合元素的方式,不暴露内部结构
设计模式·迭代器模式
未秃头的程序猿1 天前
🚀 设计模式在复杂支付系统中的应用:策略+工厂+模板方法模式实战
后端·设计模式
雨中飘荡的记忆1 天前
深入理解设计模式之单例模式
java·设计模式
8***29311 天前
能懂!基于Springboot的用户增删查改(三层设计模式)
spring boot·后端·设计模式
在未来等你2 天前
AI Agent设计模式 Day 19:Feedback-Loop模式:反馈循环与自我优化
设计模式·llm·react·ai agent·plan-and-execute