美文网首页
状态模式

状态模式

作者: hankchang | 来源:发表于2018-08-19 01:10 被阅读0次

状态模式

  • 一个对象有状态变化
  • 每次状态变化都会触发一个逻辑
  • 不能总是用 if...else 来控制

示例

  • 交通灯信号灯的不同状态

UML

UML.png
  • State 的抽离也许会想不到
// 状态 (红灯, 绿灯, 黄灯)
class State {
  constructor(color) {
    this.color = color;
  }
  handle(context) {
    console.log(`turn to ${this.color} light`);
    context.setState(this);
  }
}

// 主体
class Contest {
  constructor() {
    this.state = null;
  }
  // 获取状态
  getState() {
    return this.state;
  }
  setState(state) {
    this.state = state;
  }
}

// test
const context = new Contest();

const green = new State("green");
const yellow = new State("yellow");
const red = new State("red");

// 绿灯
green.handle(context);
console.log(context.getState());
// 黄灯
yellow.handle(context);
console.log(context.getState());
// 红灯
red.handle(context);
console.log(context.getState());
  • 状态和主体的分离

场景

有限状态机

有限状态机- "收藏" 和 "取消"

有限状态机.png 有限状态机2.png

写一个简单的 Promise

  • 实现 Promise
    • Promise 三种状态变化: pending fulfilled rejected
    • pending -> fulfilled 或者 pending -> rejected
    • 不能逆向变化
MyPromise.png Promise.png

设计原则验证

  • 将状态对象和主体对象分离, 状态的变化逻辑单独处理
  • 符合开放封闭原则

相关文章

  • State模式

    状态模式(State模式) 定义 状态模式,又称状态对象模式(Pattern of Objects for S...

  • 设计模式-状态模式

    设计模式-状态模式 设计模式 状态模式的关键是区分事物内部的状态

  • 状态模式(状态机模式)

    状态模式学习笔记 前言:文章从三方面简单阐述状态模式:是什么、为什么、如何做。这是我在工作之余自己的一些理解、思考...

  • C++设计模式(3)

    本文预览: 状态模式 组合模式 迭代器 职责链 命令 状态模式 定义:状态模式(State Pattern),允许...

  • 设计模式——状态模式

    定义 状态模式,又称状态对象模式(Pattern of Objects for States),状态模式是对象的行...

  • 第5章 -行为型模式-状态模式

    一、状态模式的简介 二、状态模式的优缺点 三、状态模式的实例

  • 状态模式

    Android进阶之设计模式 状态模式 定义: 当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变了...

  • 状态模式

    状态模式:允许对象在内部状态改变时改变它的行为,对象看起来好像修改了它的类。允许对象随着状态改变而改变行为。 策略...

  • 状态模式

    《大话设计模式》阅读笔记和总结。原书是C#编写的,本人用Java实现了一遍,包括每种设计模式的UML图实现和示例代...

  • 状态模式

    状态模式 一个对象有状态变化 每次状态变化都会触发一个逻辑 不能总是用 if...else 来控制 示例 交通灯信...

网友评论

      本文标题:状态模式

      本文链接:https://www.haomeiwen.com/subject/aovqiftx.html