Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ccnokes/simplestatemachine
Javascript state machine that keeps things simple
https://github.com/ccnokes/simplestatemachine
javascript state-machine
Last synced: about 2 months ago
JSON representation
Javascript state machine that keeps things simple
- Host: GitHub
- URL: https://github.com/ccnokes/simplestatemachine
- Owner: ccnokes
- License: mit
- Created: 2014-12-08T21:42:55.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2015-09-15T15:20:17.000Z (over 9 years ago)
- Last Synced: 2024-11-01T06:12:07.165Z (2 months ago)
- Topics: javascript, state-machine
- Language: JavaScript
- Homepage:
- Size: 277 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SimpleStateMachine
State machines are simple yet powerful. This one aims to be as simple as possible. No external dependencies.## Install
```
bower install SimpleStateMachine
```
```
npm install simple-statemachine
```## Build
To build and view locally, first clone the project and then:```
npm install
grunt serve
```
That will start a server at localhost:1337 and load the examples page.## Usage
See examples folder for usage. The example using Angular has a side-by-side comparison of using SimpleStateMachine vs. not in a pretty typical use-case. See .js file code comments for documentation.## Why?
One of the primary things front end Javascript deals with is setting and managing the state of different objects and exposing that state to the DOM. There's a lot of complexity to this: not all states can be universally reached from all other states, other objects need to be notified when a states has been entered/left, only one state can be "active" at a time, etc. I've found that this complexity can be reduced by using a state machine to manage it. This is because:- The pub/sub pattern allows for greater separation of concerns; and pub/sub is at the heart of this state machine.
- Having a common API for managing state within an app makes you more productive because you don't reinvent the wheel every time you're working on state related logic.
- Explicitly defining state makes it easier to manage rather than relying on implicitly defined state, e.g. check if some object has data, if it doesn't, it must be in an error state, so show an error message. Subscribing to the defined error state event and then showing an error message is much simpler to reason about.[This article](http://www.shopify.com/technology/3383012-why-developers-should-be-force-fed-state-machines) also explains why state machines should be used.