[XState] Create Actor in Vanilla Javascript

 

function countBehavior(state, event) {
  if (event.type === "INC") {
    return {
      ...state,
      count: state.count + 1
    }
  }
}

function createActor(behavior, initialState) {
  let currentState = initialState
  const listeners = new Set()
  return {
    send: (event) => {
      currentState = behavior(currentState, event)
      listeners.forEach(listener => {
        listener(currentState)
      })
    },
    subscribe: (listener) => {
      listeners.add(listener)
      listener(currentState)
    },
    getSnapshot: () => {
      return currentState
    }
  }
}

const actor = createActor(countBehavior, {count: 12})
actor.subscribe(console.log)

 

posted @   Zhentiw  阅读(28)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-11-30 [Java spring] Building a command-line application
2020-11-30 [NgRX] Update record in NgRX
2020-11-30 [NgRx] Sort Entity with ngrx
2020-11-30 [Java Srping] Configuring embedded Tomcat to run on https (NOT production code)
2020-11-30 [Java Spring] Profiles
2018-11-30 [Testing] Config jest to test Javascript Application -- Part 3
2017-11-30 [Javascript] Compose multiple functions for new behavior in JavaScript
点击右上角即可分享
微信分享提示