第十六章 状态模式

状态模式的定义为:当一个对象的内部状态发生改变时,会导致其行为的改变,这样看起来也像改变了对象。

例子

我们以超级玛丽游戏为例,玛丽可能会进行开枪射击、跳起顶蘑菇、蹲下躲避炮弹等等。如此多的行为,其实都可以看成是一种状态;如果采用if或者switch语句进行维护的话,难度会非常大,因为任何一种状态的添加或者删除,多会引起很大的改动;而且有时候会是跳起开枪、有时会蹲下开枪;多种组合模式的引入,更加会加剧修改成本,举例如下:

// 单个动作
var _lastAction = "";
function changeMarry(action){
    if(action == "jump"){
        // 跳跃
    }else if(action == ''move){
        // 移动
    }else{
        // 默认
    }
    _lastAction = action;
}
    
// 多个动作 感觉代码超出了能维护的方向了..
var _lastAction1 = "", _lastAction2 = "";
function changeMarry(action1, action2){
    if(action1 == "jump"){
        // 跳跃
    }else if(action1 == 'shoot'){
        // 设计
    }else if(action1 == 'move' && action2 == 'shoot'){
        // 移动设计
    }else if(action1 == 'jump' && action2 == 'shoot'){
        // 条约中射击
    }
    _lastAction1 = action1 || '';
    _lastAction2 = action2 || '';
}

鉴于上述代码的糟糕情况,我们可以引入状态模式,具体的实现如下:

// 创建状态
var _marryState = function(){
    var _currentState = {},
        states = {
            jump: funciton(){
                // 跳跃
                console.log("跳跃");
            },
            move: funciton(){
                // 移动
                console.log("移动");
            },
            shoot: funciton(){
                // 射击
                console.log("射击");
            },
            squat: funciton(){
                // 蹲下
                console.log("蹲下");
            }
        };
        
    // 动作控制类
    var Action = {
        changeState: function(){
            var args = arguments;
            _currentState = {};
            if(arg.length){
                for(var i=0, len=arg.length; i<len; i++){
                    _currentState[arg[i]]] = true;
                }
            }
            return this;
        },
        
        goes: function(){
            for(var i in _currentState){
                _currentState[i] && states[i] && state[i]();
                _currentState[i] = false;
            }
        }
    }
        
    return{
        change: Action.changeState,
        goes: Action.goes
    }
}
    
// 创建一个超级玛丽
 var _marry = new MarryState();
 _marry.change('jump', 'shoot')  // 跳跃与设计动作
        .goes()
        .goes()
        .change('shoot').goes();  // 执行动作

状态模式是解决程序中臃肿的分支判断语句问题,将每个分支转化成一种状态独立出来,方便每种状态的管理而又不至于每次执行要遍历所有的分支。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,188评论 25 709
  • 接触前端两三个月的时候,那时候只是听说设计模式很重要,然后我就去读了一本设计模式的书,读了一部分,也不知道这些设计...
    艰苦奋斗的侯小憨阅读 8,250评论 2 39
  • 甜水园是我在北京最熟悉的地标,因为在那里我生活了将近六年,在北京经历了好几次搬家,但不管怎么搬,甜水园像是在我心里...
    小食光阅读 4,306评论 2 0
  • 故事简介:家庭很富裕但高考后父母却离婚的男生--于煜,在高考后来到了荆楚理工学院,心高气傲内心却很脆弱的他在接下来...
    洛苋阅读 4,300评论 2 5
  • 初恋的朦胧诗,曾经发表在当年的校刊上 ,怀念我那纯真美好的黄金岁月: 寂寞的星期天 ------给你 总是把门关上...
    焰归来阅读 2,435评论 0 7

友情链接更多精彩内容