This is the code repository for MobX Quick Start Guide, published by Packt.
Apply functional Reactive programming for simple and scalable state management with MobX
MobX is a simple and highly scalable state management library in JavaScript. Its abstractions can help you manage state in small to extremely large applications. However, if you are just starting out, it is essential to have a guide that can help you take the first steps. This book aims to be that guide that will equip you with the skills needed to use MobX and effectively handle the state management aspects of your application.
This book covers the following exciting features:
- Explore the fundamental concepts of MobX, such as observables, actions, and reactions
- Use observables to track state and react to its changes with validations and visual feedback (via React Components)
- Create a MobX observable from different data types
- Define form data as an observable state and tackle sync and async form validations
- Use the special APIs to directly manipulate observables, tracking its changes, and discovering the reasons behind a change
If you feel this book is for you, get your copy today!
All of the code is organized into folders. For example, Chapter02
. There are no codes for Chapter 1.
The code is formatted like so:
connect(mapStateToProps, mapDispatchToProps, mergeProps, options)(Component)
Following is what you need for this book: This book is for web developers who want to implement easy and scalable state management for their apps. Knowledge of HTML, CSS, and JavaScript is assumed
With the following software and hardware list you can run all code files present in the book (Chapter 02-09).
Chapter | Software required | OS required |
---|---|---|
All | Visual Studio Code or any other preferred editor. Modern Web Browser like Chrome, Firefox, Edge or Safari | Windows, Mac OS X, and Linux (Any) |
We also provide a PDF file that has color images of the screenshots/diagrams used in this book. Click here to download it.
Click on the following link to see the Code in Action:
Pavan Podila has been building frontend applications since 2001 and has used a variety of tools, technologies, and platforms, from Java Swing, WPF with .Net/C#, Cocoa on macOS and iOS, to the web platform with frameworks like React and Angular. He has been working with React since 2013 and MobX since 2016. He is a colead of the Interactive Practice at Publicis.Sapient, where he builds large financial apps for web and mobile platforms.
Earlier, he was a Microsoft MVP for client application development (2008-2011), a published author of WPF Control Development Unleashed (Addison-Wesley). He created QuickLens, a Mac App for UI designers/developers, and authored several articles and video courses on Tuts+.
Pavan is a Google Developer Expert (GDE) for web technologies and currently authors courses on The UI Dev. He is a regular speaker at meetups, conferences, and workshops. When time permits, you can find him sketching on iPad or playing Ping-Pong
Michel Weststrate is tech lead and open source evangelist at Mendix. He has been active as both a frontend and backend developer in different stacks. An occasional speaker at software conferences, he has authored video courses on egghead.
Intrigued by several (transparent) reactive programming libraries, he researched and worked on making the ReactJS framework more reactive while addressing predictability and maintainability constraints in other solutions. This led to mobservable (nowadays MobX), which was quickly adopted at Mendix.
He's very active in the open source software community, and he authored MobX, Immer, and several small libraries, and coauthored MobX-State-Tree.
Go to https://packt-mobx.surge.sh to see the app running live. Source maps have been included so you can browse the source for the examples in DevTools.
- Install Node
- Clone this repo using git to a local folder
- Run
npm install
on the top-level folder - Run
npm start
to launch the app on http://localhost:3000
- Needed to run the example for Chapter 03: A React App with MobX.
- Register for an API Key.
- Create a file called
.env.local
at the top level, as a peer of.env
- Put the following line with your API Key:
REACT_APP_GOODREADS_APIKEY = <API-Key>