js组合命令模式

总结一种js的设计模式:组合命令模式

一.拿实际应用场景来举例:比如双十一的时候,业务部门需要我们丰富一下购物车结算功能:

  1. 判断商品是否过期
  2. 计算优惠
  3. 发送账单消息给用户

那么这三个命令一般是在用户点击“结算”按钮触发的,那么把他们封装在一起

var MakeGroup = function() {
  return {
    commandList: [],
    add: function( command ) {
      this.commandList.push( command );
    },
    execute: function() {
      for (let i = 0; i < this.commandList.length; i++) {
        this.commandList[ i ].execute();
      }
    }
  }
}

var isOverDue = {
  execute: function() {
    console.log( '判断商品是否过期' );
  }
}

var calculateDiscount = {
  execute: function() {
    console.log( '计算优惠' );
  }
}

var sendOrder = {
  execute: function() {
    console.log( '发送账单消息给用户' );
  }
}

var payGroup = MakeGroup();

payGroup.add( isOverDue );
payGroup.add( calculateDiscount );
payGroup.add( sendOrder );

payGroup.execute();
// 判断商品是否过期
// 计算优惠
// 发送账单消息给用户

二.还有一种的命令模式的应用场景有很多:PS、word、各种markdown编辑器,总而言之,所有的音频、视频、图片、文字处理的应用都有撤销的功能,下面来模拟一下执行命令与撤销命令的功能

下面这段代码放到浏览器控制台即可查看效果,模拟的是:按下键盘上的键执行命令,按键盘的“esc”键即可撤销命令

var keyCommand = {
  commandList: [],
  execute: function(key) {
    console.log( '按下了 ' + key + ' 键' );
    this.commandList.push( key );
  },
  revoke: function() {
    if (this.commandList.length > 0) {
      console.log( '撤销了 ' + this.commandList.pop() + ' 键按下操作' )
    }
    else {
      console.log( '没有操作可以撤销了!' );
    }
  }
}

document.body.onkeydown = function(e) {
  if (e.key === 'Escape') {
    keyCommand.revoke();
  }
  else {
    keyCommand.execute( e.key );
  }
}

按下了 q 键
按下了 w 键
按下了 e 键
按下了 r 键
按下了 t 键
撤销了 t 键按下操作
撤销了 r 键按下操作
撤销了 e 键按下操作
撤销了 w 键按下操作
撤销了 q 键按下操作
没有操作可以撤销了!
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值