闭包实现命令模式

面向对象版本:预先植入的命令接收者被当成对象的属性保存起来

var Tv = {
    open: function() {
        console.log('open tv');
    },
    close: function() {
        console.log('close tv');
    }
};

var OpenTvCommand = function(receiver) {
    this.receiver = receiver;
}

OpenTvCommand.prototype.excute = function() {
    this.receiver.open();
}

OpenTvCommand.prototype.undo = function() {
    this.receiver.close();
}

var setCommand = function(command) {
    document.querySelector('#excute').onclick = function() {
        command.excute();
    };
    document.querySelector('#undo').onclick = function() {
        command.undo();
    };
};

setCommand(new OpenTvCommand(Tv));

闭包版本:命令接收者被封闭在闭包形成的环境中

var Tv = {
    open: function() {
        console.log('open tv');
    },
    close: function() {
        console.log('close tv');
    }
};

var createCommand = function(receiver) {
    var excute = function() {
        receiver.open();
    };
    var undo = function() {
        receiver.close();
    };
    return {
        excute: excute,
        undo: undo,
    };
}

var setCommand = function(command) {
    document.querySelector('#excute').onclick = function() {
        command.excute();
    };
    document.querySelector('#undo').onclick = function() {
        command.undo();
    };
};

setCommand(createCommand(Tv));

你可能感兴趣的:(闭包实现命令模式)