Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/robertgonzales/compare-react-state-management

React createContext vs Apollo vs MobX vs Redux in a simple todo app.
https://github.com/robertgonzales/compare-react-state-management

apollo mobx react reactjs redux state-management

Last synced: 2 months ago
JSON representation

React createContext vs Apollo vs MobX vs Redux in a simple todo app.

Awesome Lists containing this project

README

        

This repo is a collection of apps, structured to compare popular React state management libraries. Each app is the exact same todo app, but uses a different state management library. Presentational components and utils are shared, and business logic and container components are analogous.

I hope this repo is useful to anyone that may already be familiar with one library and interested in another.

### Use this repo to compare:
- How state is updated and components are connected.
- Boilerplate and configuration.
- Common and best practices.

### Libraries implemented:
- [Apollo](https://www.apollographql.com/docs/react/)
- [MobX](https://mobx.js.org/)
- [Redux](https://redux.js.org/)
- [React.createContext](https://github.com/thejameskyle/create-react-context)

### How to use:
- [See shared presentational components and utils](https://github.com/robertgonzales/compare-react-state-management/tree/master/client/src/shared).
- [Familiarize yourself with implementation of library you already know](https://github.com/robertgonzales/compare-react-state-management/tree/master/client/src).
- [**Compare to another library's state logic and connected components**](https://github.com/robertgonzales/compare-react-state-management/tree/master/client/src).

![redux-vs-apollo-example](https://user-images.githubusercontent.com/7729885/36496808-7257e160-1707-11e8-8bce-0265146fa7ab.jpg)

### To run the project:
Start the GraphQL server on `localhost:8080/graphql`:
```
$ cd server
$ npm install
$ npm start
```
Start the React client on `localhost:3000`:
```
$ cd client
$ npm install
$ npm start
```

NOTE: You can select the app to render inside `client/src/index.js`.

In the future I may add more complex usage examples, especially where one library really excels. For example, optimistic UI is really nice in Apollo and interesting to implement in the others. For now I've just tried to keep everything as simple as possible.

Thanks to igorlima for the GraphQL server: https://github.com/igorlima/todo-mongo-graphql-server