框架建设实战5——状态机组件

在大部分业务中,状态机处理比较常见,且相当重要。比如电商的订单场景。

状态机:英文叫StateMachine。顾名思义,根据状态进行流程驱动的机器。

状态机的语义比较容易理解。调用示例代码如下:

java 复制代码
builder.externalTransition()

            .from(States.STATE1)

            .to(States.STATE2)

            .on(Events.EVENT1)

            .when(checkCondition())

            .perform(doAction());

其语义解释为:某个状态跳转到下个状态,会通过事件event来触发,并判断满足什么样的条件;若满足,则状态发生变更,并执行一定的动作。

方案实现:

本方案直接采用阿里大佬张建飞(Frank)的方案:状态机说明及实现

组件命名:

当然,框架的组件,无非将上述方案开源的代码 fork一份,自行包装即可 。由于此状态机方案无状态,在此采用util 类型的组件。即可以将之命名为:frame-util-statemachine

相关推荐
Yvonne爱编码13 小时前
CSS- 4.2 相对定位(position: relative)
前端·css·状态模式·html5·hbuilder
鸡吃丸子16 小时前
常见的实时通信技术(轮询、sse、websocket、webhooks)
前端·websocket·状态模式
xiaolin033317 小时前
【设计模式】- 行为型模式1
设计模式·状态模式·责任链模式·策略模式·命令模式·模板方法模式·行为型模式
敲代码的小吉米1 天前
前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)
前端·javascript·pdf·状态模式
小赵面校招1 天前
基于Session实现短信登录全流程详解
状态模式
众乐乐_20082 天前
Java 后端给前端传Long值,精度丢失的问题与解决
java·前端·状态模式
Yvonne爱编码2 天前
CSS- 2.1 实战之图文混排、表格、表单
前端·css·html·github·状态模式·html5·hbuilder
Yvonne爱编码2 天前
CSS- 1.1 css选择器
前端·css·状态模式·html5·hbuilder
lyw2056194 天前
框架篇八股(自用)
状态模式
Cuit小唐6 天前
C++ 状态模式详解
开发语言·c++·状态模式