跳至主要內容

命令模式

Mr.Dylin...小于 1 分钟设计模式F_设计模式6.设计模式

命令模式

命令模式与策略模式open in new window有些类似, 在 JavaScript 中它们都是隐式的。

重要性: 较低

JavaScript 中的命令模式

命令模式在 JavaScript 中也比较简单, 下面代码中对按钮命令进行了抽离, 因此可以复杂项目中可以使用命令模式将界面的代码和功能的代码交付给不同的人去写。

const setCommand = function(button, command) {
  button.onClick = function() {
    command.excute()
  }
}

// --------------------  上面的界面逻辑由A完成, 下面的由B完成

const menu = {
  updateMenu: function() {
    console.log('更新菜单')
  },
}

const UpdateCommand = function(receive) {
  return {
    excute: receive.updateMenu,
  }
}

const updateCommand = UpdateCommand(menu) // 创建命令

const button1 = document.getElementById('button1')
setCommand(button1, updateCommand)
上次编辑于:
贡献者: zddbic