JavaScript 设计模式之状态模式

状态模式

假使我们有如下状态

定义状态类

javascript 复制代码
// 比如有一种状态
const State = function () {
  let __currentStatus = {}
  const status = {
    'A': function () {
      console.log('状态A')
    },
    'B': function () {
      console.log('状态B')
    },
    'C': function () {
      console.log('状态C')
    }
  }
  const ActionStatus = {
    change: function () {
      let args = arguments
      __currentStatus = {}
      for (let key of args) {
        __currentStatus[key] = true
      }
      return this
    },
    goes: function () {
      console.log('执行了一次操作')
      for (let key in __currentStatus) {
        status[key] && status[key]()
      }
      return this
    }
  }
  return {
    change: ActionStatus.change,
    goes: ActionStatus.goes
  }
}

状态A、B、C 是不同的状态,可能会有多种状态同时出现的情况,我们可以这样使用

使用

javascript 复制代码
const test = new State()
test.change('A', 'B').goes().goes().change('A', 'C').goes()
/**
执行了一次操作
状态A
状态B
执行了一次操作
状态A
状态B
执行了一次操作
状态A
状态C
*/

或者这样使用

javascript 复制代码
State().change('A', 'B').goes().goes().change('A').goes()

/**
执行了一次操作
状态A
状态B
执行了一次操作
状态A
状态B
执行了一次操作
状态A
*/

我们在商城订单状态较多的情况就可以使用这种模式,比如在待收货前的几种状态下都可以发起某些操作,就可以直接使用 change(x,x,x,x) 的形式去判断逻辑了,而不用再一个个的用 if 叠加判断了

总结

++状态模式既是解决程序中臃肿的分支判断语句问题,将每个分支转化为一种状态独立出来,方便每种状态的管理又不至于每次执行时遍历所有分支。在程序中到底产出哪种行为结果,决定于选择哪种状态,而选择何种状态又是在程序运行时决定的。当然状态模式最终的目的即是简化分支判断流程。++

相关推荐
西幻凌云4 分钟前
认识设计模式——单例模式
c++·单例模式·设计模式·线程安全·饿汉和懒汉
Mintopia5 分钟前
🤖 AIGC与人类协作:Web内容生产的技术分工新范式
前端·javascript·aigc
顾安r6 分钟前
11.11 脚本网页 跳棋
前端·javascript·游戏·flask·html
鹏多多23 分钟前
H5开发避坑!解决Safari浏览器的video会覆盖z-index:1的绝对定位元素
前端·javascript·vue.js
一只小阿乐1 小时前
vue3封装alert 提示组件 仿element-plus
前端·javascript·vue.js·vue3
爱吃烤鸡翅的酸菜鱼1 小时前
【Java】基于策略模式 + 工厂模式多设计模式下:重构租房系统核心之城市房源列表缓存与高性能筛选
java·redis·后端·缓存·设计模式·重构·策略模式
华洛1 小时前
解读麦肯锡报告:Agent落地的六大经验教训
前端·javascript·产品经理
艾小码1 小时前
还在重复造轮子?掌握这7个原则,让你的Vue组件复用性飙升!
前端·javascript·vue.js
探索宇宙真理.1 小时前
React Native Community CLI命令执行 | CVE-2025-11953 复现&研究
javascript·经验分享·react native·react.js·安全漏洞
. . . . .2 小时前
React底层原理
javascript·react.js