命令模式 男娘i 2022-06-05 22:40 112阅读 0赞 #### 命令模式 #### 命令模式最常见的应用场景是:有时需要向某些对象发送请求,但是不知道请求的接受者是谁,也不知道请求的操作是什么。此时希望用一种松耦合的方式设计程序,使得请求发送者和请求接受者能消除彼此之间的耦合关系。 var button1 = document.getElementById('btn1') var button2 = document.getElementById('btn2') var button3 = document.getElementById('btn3') var setCommand = function (button,command) { button.onclick = function () { command.execute() } } var MenuBar = { refresh: function () { console.log('刷新菜单目录') } } var SubBar = { add: function () { console.log('增加子菜单') }, del: function () { console.log('删除子菜单') } } var RefreshMenuBarcommand = function (receiver) { this.receiver = receiver; } RefreshMenuBarcommand.prototype.execute = function () { this.receiver.refresh() } var AddSubMenuCommand = function (receiver) { this.receiver = receiver } AddSubMenuCommand.prototype.execute = function () { this.receiver.add() } var DelSubMenuCommand = function (receiver) { this.receiver = receiver } DelSubMenuCommand.prototype.execute = function () { this.receiver.del() } var refreshMenuBarcommand = new RefreshMenuBarcommand(MenuBar) var addSubMenuCommand = new AddSubMenuCommand(SubBar) var delSubMenuCommand = new DelSubMenuCommand(SubBar) setCommand(button1,refreshMenuBarcommand) setCommand(button2,addSubMenuCommand) setCommand(button3,delSubMenuCommand) #### 命令模式实现重放 #### <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <button id="replay">播放录像</button> <script> var Ryu = { attack:function () { console.log('攻击') }, defense:function () { console.log('防御') }, jump:function () { cosole.log('跳跃') }, crouch:function () { console.log('蹲下') } } var makeCommand = function (receiver, state) { return function () { recevier[state]() } } var commands = { '119':'jump', '115':'crouch', '97':'defense', '100':'attack', } var commandStack = [] document.onkeypress = function (ev) { var keyCode = ev.keyCode command = makeCommand(Ryu,commands[keyCode]) if(command){ command() commandStack.push(command) } } document.getElementById('replay').onclick = function () { var command; while(command = commandStack.shift()){ command() } } </script> </body> </html> #### 宏命令 #### var closeDoor = { execute:function () { console.log('关门') } } var openDoor = { execute:function () { console.log('开门') } } var MarcoCommand = function () { return { commandList: [], add:function (command) { this.commandList.push(command) }, execute:function () { for(var i=0,command;command = this.commandList[i++]){ command.execute() } } } } var macroCommand = new MarcoCommand() macroCommand.add(closeDoor) macroCommand.add(openDoor) macroCommand.execute();
相关 命令模式 最近在看CQRS,里边涉及到了命令模式,这篇文章就是对命令模式进行一个回顾再学习,文中的主要内容来自这篇文章:https://www.jianshu.com/p/5901e76 喜欢ヅ旅行/ 2022年10月29日 04:27/ 0 赞/ 18 阅读
相关 命令模式 ![这里写图片描述][SouthEast] / 士兵 @author Administrator / public class Soldier { 浅浅的花香味﹌/ 2022年06月06日 00:05/ 0 赞/ 65 阅读
相关 命令模式 命令模式 命令模式最常见的应用场景是:有时需要向某些对象发送请求,但是不知道请求的接受者是谁,也不知道请求的操作是什么。此时希望用一种松耦合的方式设计程序,使得请 男娘i/ 2022年06月05日 22:40/ 0 赞/ 113 阅读
相关 命令模式 1.使用场景: 所谓命令模式就是将一个请求封装成一个对象,从而让你使用不同的请求把客户端参数化,对请求排队或者记录请求日志,可以提供命令的撤销和恢复功能。在数据库的事务处理 忘是亡心i/ 2022年05月31日 09:14/ 0 赞/ 106 阅读
相关 命令模式 定义 命令模式将请求封装成对象,以便使用不同的请求,队列,或者日志来参 数化其他对象。命令模式也支持可撤销的操作。 模式结构 盗用一下UML图 ![命令模 àì夳堔傛蜴生んèń/ 2022年05月09日 09:54/ 0 赞/ 97 阅读
相关 命令模式 命令模式:是一种数据驱动的设计模式,它属于行为型模式。请求以命令的形式包裹在对象中,并传给调用对象。调用对象寻找可以处理该命令的合适的对象,并把该命令传给相应的对象,该对象执行 拼搏现实的明天。/ 2021年09月17日 03:48/ 0 赞/ 194 阅读
相关 命令模式 18.命令模式 ![70][] class Program { static void Main(string[] ar àì夳堔傛蜴生んèń/ 2021年09月17日 00:04/ 0 赞/ 222 阅读
相关 命令模式 1、基本概念: 在软件系统中,“ 行为请求者 ”与“ 行为实现者 ”通常呈现一种“ 紧耦合 ”。但在 [某些][Link 1] 场合,比如要对行为进行“记录、撤 喜欢ヅ旅行/ 2021年09月14日 12:44/ 0 赞/ 278 阅读
相关 命令模式 一 点睛 日常生活中,我们出去吃饭都会遇到下面的场景。 ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_ 叁歲伎倆/ 2021年07月24日 16:11/ 0 赞/ 257 阅读
相关 命令模式 令模式(Command Pattern)是一种数据驱动的设计模式,它属于行为型模式。请求以命令的形式包裹在对象中,并传给调用对象。调用对象寻找可以处理该命令的合适的对象,... 小灰灰/ 2020年06月13日 05:45/ 0 赞/ 701 阅读
还没有评论,来说两句吧...