zoukankan      html  css  js  c++  java
  • JS 设计模式五 -- 命令模式

    概念

    命令模式中的命令(command) 指的是 一个执行某些待定事情的指令。

    用一种松耦合的方式来设计程序,使得请求发送者和请求接收者能够消除彼此之间的耦合关系。

    例子

    假设html结构如下:
    <button id="button1">刷新菜单目录</button>
    <button id="button2">增加子菜单</button>
    var setCommand = function(button,func) {
        button.onclick = function(){
            func();
        }
     }; 
     var MenuBar = {
        refersh: function(){
            alert("刷新菜单界面");
        }
     };
     var SubMenu = {
        add: function(){
            alert("增加菜单");
        }
     };
     // 刷新菜单
     var RefreshMenuBarCommand = function(receiver) {
        return function(){
            receiver.refersh();    
        };
     };
     // 增加菜单
     var AddSubMenuCommand = function(receiver) {
        return function(){
            receiver.add();    
        };
     };
    // 刷新菜单 var refershMenuBarCommand = RefreshMenuBarCommand(MenuBar); // 增加菜单 var addSubMenuCommand = AddSubMenuCommand(SubMenu); setCommand(b1,refershMenuBarCommand); setCommand(b2,addSubMenuCommand);

    理解宏命令

    宏命令是一组命令的集合,通过执行宏命令的方式,可以一次执行一批命令。

    这样类似把页面的所有函数方法放在一个数组里面去,然后遍历这个数组,依次执行该方法。

    例子

    var command1 = {
        execute: function(){
            console.log(1);
        }
    }; 
    var command2 = {
        execute: function(){
            console.log(2);
        }
    };
    var command3 = {
        execute: function(){
            console.log(3);
        }
    };
    // 定义宏命令,command.add方法把子命令添加进宏命令对象,
    // 当调用宏命令对象的execute方法时,会迭代这一组命令对象,
    // 并且依次执行他们的execute方法。
    var command = function(){
        return {
            commandsList: [],
            add: function(command){
                this.commandsList.push(command);
            },
            execute: function(){
                for(var i = 0,commands = this.commandsList.length; i < commands; i+=1) {
                    this.commandsList[i].execute();
                }
            }
        }
    };
    // 初始化宏命令
    var c = command();
    c.add(command1);
    c.add(command2);
    c.add(command3);
    c.execute();  // 1,2,3
  • 相关阅读:
    python2.7打印中文乱码的问题解决
    Tesseract5.0训练字库,提高OCR特殊场景识别率(一)
    git比较重要但是又容易忘记的操作
    ntp局域网时间同步操作
    Flask使用原生sql语句
    Linux的tail命令查看文件
    使用gitlab的webhook进行前端自动部署
    通过queue实现前端的被动接收
    互动interactive与多行输出
    复习
  • 原文地址:https://www.cnblogs.com/gaosirs/p/10749367.html
Copyright © 2011-2022 走看看