命令模式 男娘i 2022-06-05 22:40 122阅读 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();
相关 vim 命令大全 一般模式 编辑模式 命令模式 推荐阅读:[vim入门教程][vim] [https://www.cnblogs.com/hezhiyao/p/7624831.html][vim] 第一部分:一般模式可用 柔情只为你懂/ 2022年08月17日 15:28/ 0 赞/ 250 阅读
相关 命令模式 ![这里写图片描述][SouthEast] / 士兵 @author Administrator / public class Soldier { 浅浅的花香味﹌/ 2022年06月06日 00:05/ 0 赞/ 76 阅读
相关 命令模式 命令模式 命令模式最常见的应用场景是:有时需要向某些对象发送请求,但是不知道请求的接受者是谁,也不知道请求的操作是什么。此时希望用一种松耦合的方式设计程序,使得请 男娘i/ 2022年06月05日 22:40/ 0 赞/ 123 阅读
相关 命令模式 1.使用场景: 所谓命令模式就是将一个请求封装成一个对象,从而让你使用不同的请求把客户端参数化,对请求排队或者记录请求日志,可以提供命令的撤销和恢复功能。在数据库的事务处理 忘是亡心i/ 2022年05月31日 09:14/ 0 赞/ 115 阅读
相关 命令模式 定义 命令模式将请求封装成对象,以便使用不同的请求,队列,或者日志来参 数化其他对象。命令模式也支持可撤销的操作。 模式结构 盗用一下UML图 ![命令模 àì夳堔傛蜴生んèń/ 2022年05月09日 09:54/ 0 赞/ 104 阅读
相关 命令模式 命令模式:是一种数据驱动的设计模式,它属于行为型模式。请求以命令的形式包裹在对象中,并传给调用对象。调用对象寻找可以处理该命令的合适的对象,并把该命令传给相应的对象,该对象执行 拼搏现实的明天。/ 2021年09月17日 03:48/ 0 赞/ 203 阅读
相关 命令模式 18.命令模式 ![70][] class Program { static void Main(string[] ar àì夳堔傛蜴生んèń/ 2021年09月17日 00:04/ 0 赞/ 229 阅读
相关 命令模式 1、基本概念: 在软件系统中,“ 行为请求者 ”与“ 行为实现者 ”通常呈现一种“ 紧耦合 ”。但在 [某些][Link 1] 场合,比如要对行为进行“记录、撤 喜欢ヅ旅行/ 2021年09月14日 12:44/ 0 赞/ 285 阅读
相关 命令模式 一 点睛 日常生活中,我们出去吃饭都会遇到下面的场景。 ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_ 叁歲伎倆/ 2021年07月24日 16:11/ 0 赞/ 263 阅读
相关 命令模式 令模式(Command Pattern)是一种数据驱动的设计模式,它属于行为型模式。请求以命令的形式包裹在对象中,并传给调用对象。调用对象寻找可以处理该命令的合适的对象,... 小灰灰/ 2020年06月13日 05:45/ 0 赞/ 716 阅读
还没有评论,来说两句吧...