写了状态模式的切换,以及分支循环。but 怎么实现子状态嵌套呢?

/**
* by JackChen 2016-3-26 11.51.20
*
* 状态模式:
* 一个状态到另一个状态的变换。其实可以把程序中变换复杂的流程抽离出来。
* 譬如Level2中状态的变换比较复杂,完全可以又外部来处理状态的变换。
* 通过在状态对象中指定切换状态的条件判断。读取当前的运行情况决定。
* 而核心类只需管理自己需要进行什么具体操作即可,不用管外部切换
*/
/////////////////////////
//状态类
// 设计自己的状态名称,切换状态时根据名称查找
var StateItem = function(name){
this._name = name;
}
StateItem.prototype = {};
StateItem.prototype.construct = StateItem;
//更新自己坐标同时,同步到外部元素
Object.defineProperties(StateItem.prototype, {
Name: {
get: function() {
return this._name;
},
set: function(v) {
this._name = v;
}
}
});
//运行函数,相当于接口,用于运行当前状态的代码。获得下个状态的名称
StateItem.prototype.run = function() {
return ;
}; //////////////////////////////////
//状态管理类
var StateManager = function () {
this._group = {};
this._entrance = "";
};
StateManager.prototype = {};
StateManager.prototype.construct =StateManager; //以名字为索引建立状态表
StateManager.prototype.add = function(stateItem) {
if (!this._group[stateItem.Name]) {
this._group[stateItem.Name] = stateItem;
return true;
}
else {
return false;
};
}; //设置唯一入口
StateManager.prototype.setEntrance = function(stateItemName) {
this._entrance = stateItemName;
}; //总体运行,查找当前入口函数,得到运行后下个状态名称,再查找这个名称的函数
//一旦下个状态不可知,则结束运行
StateManager.prototype.run = function(begeinState) {
var nextState;
nextState = this._group[this._entrance];
while(nextState){
var nextName = nextState.run();
console.log(nextState.Name);
nextState = this._group[nextName];
}
}; /////////////////////////////////
//测试 //外部对流程的改变之处
var needTerminalRiskManager = true;
var needOnline = false; var manager = new StateManager(); //开始
var begin = new StateItem("begin");
begin.run = function () {
return "appSelection";
};
manager.add(begin);
manager.setEntrance("begin"); //应用选择
var appSelection = new StateItem("appSelection");
appSelection.run = function () {
return "appInit";
};
manager.add(appSelection); //应用初始化
var appInit = new StateItem("appInit");
appInit.run = function () {
return "ReadAppData";
};
manager.add(appInit); //读应用数据
//这里决定了下个状态的切换方式。
//同样可以变成是调用自己形成循环
var ReadAppData = new StateItem("ReadAppData");
ReadAppData.run = function () {
if (needTerminalRiskManager) {
return "TRiskManager";
}
else{
return "DataAuthentic";
};
};
manager.add(ReadAppData); //终端风险管理
var TRiskManager = new StateItem("TRiskManager");
TRiskManager.run = function () {
return "TAAnalysis";
};
manager.add(TRiskManager); //静态数据认证
var DataAuthentic = new StateItem("DataAuthentic");
DataAuthentic.run = function () {
return "ProcRestric";
};
manager.add(DataAuthentic); //处理限制
var ProcRestric = new StateItem("ProcRestric");
ProcRestric.run = function () {
return "CardHolderVerify";
};
manager.add(ProcRestric); //持卡人认证
var CardHolderVerify = new StateItem("CardHolderVerify");
CardHolderVerify.run = function () {
return "TAAnalysis";
};
manager.add(CardHolderVerify); //终端行为分析
var TAAnalysis = new StateItem("TAAnalysis");
TAAnalysis.run = function () {
return "CAC";
};
manager.add(TAAnalysis); //卡片行为分析
var CAC = new StateItem("CAC");
CAC.run = function () {
return "OnlineDecison";
};
manager.add(CAC); //联机判定
var OnlineDecison = new StateItem("OnlineDecison");
OnlineDecison.run = function () {
if (needOnline) {
return "OnlineProc";
}
else {
return "Completion";
};
};
manager.add(OnlineDecison); //交易结束
var Completion = new StateItem("Completion");
Completion.run = function () {
return "end";
};
manager.add(Completion); //发卡行在线认证
var OnlineProc = new StateItem("OnlineProc");
OnlineProc.run = function () {
return "ScriptProc";
};
manager.add(OnlineProc); //发卡行脚本
var ScriptProc = new StateItem("ScriptProc");
ScriptProc.run = function () {
return "Completion";
};
manager.add(ScriptProc); //结束
var end = new StateItem("end");
end.run = function () {
return;
};
manager.add(end); manager.setEntrance("begin"); manager.run();

  

javascript 写状态模式的更多相关文章

  1. JavaScript设计模式 - 状态模式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. JavaScript设计模式——状态模式

    状态和行为: 所谓对象的状态,通常指的就是对象实例的属性的值:而行为指的就是对象的功能,再具体点说,行为大多可以对应到方法上. 状态模式的功能就是分离状态的行为,通过维护状态的变化,来调用不同状态对应 ...

  3. javascript设计模式--状态模式(State)

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 【设计模式】Javascript设计模式——状态模式(行为型)

    注:这个模式是非常聪明的,很有点数学中组合的意思,现在,来看下这个模式是怎么个思想. 问题提出:假如某个操作有三种可能,分别为1,2,3,还可能是组合,比如先执行1,再执行2或者先执行2再执行3或者1 ...

  5. javascript 写策略模式,商场收银打折优惠策略

    [Decode error - output not utf-8] ----------------------------- 购物清单 方便面 : 100 x 50 = 5000 | 4000 菊花 ...

  6. 游戏开发设计模式之状态模式 & 有限状态机 & c#委托事件(unity3d 示例实现)

    命令模式:游戏开发设计模式之命令模式(unity3d 示例实现) 对象池模式:游戏开发设计模式之对象池模式(unity3d 示例实现) 原型模式:游戏开发设计模式之原型模式 & unity3d ...

  7. 轻松掌握:JavaScript状态模式

    状态模式 状态模式(State)允许一个对象在其内部状态改变的时候改变它的行为,对象看起来似乎修改了它的类. 状态模式的使用场景也特别明确,有如下两点: 一个对象的行为取决于它的状态,并且它必须在运行 ...

  8. 再起航,我的学习笔记之JavaScript设计模式19(状态模式)

    状态模式 概念介绍 状态模式(State):当一个对象的内部状态发生改变时,会导致其行为的改变,这看起来像是改变了对象 示例演示 在我们写项目的过程中或多或少会遇到如下的多分支判断 function ...

  9. JavaScript状态模式及状态机模型

    这是一篇,我自己都看不完的文章... 文章大体就两部分: 状态模式的介绍 状态机模型的函数库javascript-state-machine的用法和源码解析 场景及问题背景: 我们平时开发时本质上就是 ...

随机推荐

  1. Jquery常用方法篇(一)

    1.add方法:将匹配的元素添加到当前的jquery对象集合中. 语法 add(expr,[context]) 参数1表示 用于匹配元素选择器(待添加的对象),或者用于动态生成的HTML代码(字符串) ...

  2. 东芝超级本从win8到win7

    东芝超级本从win8到win7 2014年2月20日 11:08:46   1. 进入BIOS     调出关机选项,按住shift不松手,然后点选关机,彻底关机后,按住f2不松手,按下电源开机,就进 ...

  3. 在Java中如何用String类中的indexof方法得到一个词的出现频率

    public class Test{ public static void main(String[] args) { String s="hello jack hello look me ...

  4. 【推荐】JAVA基础◆浅谈3DES加密解密

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

  5. 齐全的IP地址查询接口及调用方法(转)

    设计蜂巢IP地址查询接口:http://www.hujuntao.com/api/ip/ip.php 腾讯IP地址查询接口:http://fw.qq.com/ipaddress 新浪IP地址查询接口: ...

  6. 使用phpize建立php扩展(Cannot find config.m4)(转)

    php源码:/root/soft/php-5.3.4php安装: /usr/local/php [root@ns root]# phpizeCannot find config.m4.Make sur ...

  7. IPv6 neighbor discovery

    IPv6 neighbor discovery By stretch | Thursday, August 28, 2008 at 5:03 a.m. UTC Neighbor Discovery P ...

  8. 在MyEclipse中如何去掉JS或jsp语法错误提示!

    在MyEclipse中如何去掉JS或jsp语法错误提示! 关于在 MyEclipse 上 WEB 工程里面的 JS/JSP 经常会有语法错误提示,这是由于 MyEclipse 对其语法要求相当严格所造 ...

  9. day-1

    /* 倒计时就要结束了 在机房的最后一个晚上 恩 就要结束了 上午考试 下午背板 找了几个原题敲了敲 晚上zjk老妈送的饭 撑死死死死了 好吃23333 吃饭完和zjk在机房门口楼梯上聊了一会 恩 以 ...

  10. js 注册手机摇动事件

    var rockModule = (function () { //监听手机摇动事件 if (window.DeviceMotionEvent) { window.addEventListener(' ...