Redux Crash Course
@jumbosushi
data:image/s3,"s3://crabby-images/f8024/f8024a804f8d4e72c6fe98e3eff721ec8aabb5ae" alt=""
data:image/s3,"s3://crabby-images/f5888/f5888efb2aeee74a406ec18fb16968092752bfcc" alt=""
data:image/s3,"s3://crabby-images/26331/26331d72c1d0b68a002c5f75e7a99d305e9c9130" alt=""
data:image/s3,"s3://crabby-images/f43b7/f43b7b0cc6764738acabc1708e4279ef7cc7a574" alt=""
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
WHY
WHAT
HOW
WHAT
HOW
data:image/s3,"s3://crabby-images/53052/53052ad2c4ff608d159df263a69fd19b8cbacc85" alt=""
Why use Redux?
What problem does Redux solve?
STATE
@christianalfoni
A data you use to populate a template
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
data:image/s3,"s3://crabby-images/3ac2a/3ac2a7a32284213823d8152b5f73ffa6e9b9a282" alt=""
data:image/s3,"s3://crabby-images/9d28b/9d28bee0745dba07115995ca5ad2ba79b81236da" alt=""
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
data:image/s3,"s3://crabby-images/d7cc0/d7cc0aacaae1b33a8e6164124b1e1ae8b0265d83" alt=""
Model
Model
Model
View
View
View
data:image/s3,"s3://crabby-images/d7cc0/d7cc0aacaae1b33a8e6164124b1e1ae8b0265d83" alt=""
data:image/s3,"s3://crabby-images/b329b/b329ba1a40ab298a7c187ac98304da8c19500dc4" alt=""
data:image/s3,"s3://crabby-images/fef68/fef68ebfd74473045da22c0e42ff87732551c7de" alt=""
data:image/s3,"s3://crabby-images/53bac/53baca94f13617ff9b78cae673b32037f2bc7c11" alt=""
STATE
data:image/s3,"s3://crabby-images/6de25/6de25a7baef7497b724cfd1859968fd81ff43737" alt=""
Flux
Elm
data:image/s3,"s3://crabby-images/e96c2/e96c2fe289019cf3527ef9d154c166f407902348" alt=""
Elm
(action, state) => state
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
WHY
WHAT
WHAT
HOW
WHY
(state) => view
Action
Reducers
dispatch
oldState
Store
Single source of truth
State is read-only
Changes are made with pure functions
data:image/s3,"s3://crabby-images/9d34b/9d34bc07822a6aa1d0d059bf5b736a013145187c" alt=""
How is it different from React???
data:image/s3,"s3://crabby-images/841c2/841c2537fed76a512d9d72fa033bb4d566b8e98f" alt=""
data:image/s3,"s3://crabby-images/841c2/841c2537fed76a512d9d72fa033bb4d566b8e98f" alt=""
data:image/s3,"s3://crabby-images/841c2/841c2537fed76a512d9d72fa033bb4d566b8e98f" alt=""
Store ≈ this.state
Actions & Reducers ≈ this.setState
always render with from store
≈ re-render with this.setState
It's about giving the application a single state (store)
Lifting the state
data:image/s3,"s3://crabby-images/c39dc/c39dc406b024394747e1407037be1b3d5a31a25d" alt=""
Lifting the state
data:image/s3,"s3://crabby-images/c39dc/c39dc406b024394747e1407037be1b3d5a31a25d" alt=""
Eventually, React will start doing more than it should.
The Role of the Store
- Hold the state
- Expose state by store.getState()
- Update state by store.dispatch(action)
- Add a listener with store.subscribe(listener)
Following examples are inspired from http://mae.chab.in/archives/2885
Store Code
// Create initial state
const initialState = {
value: null,
};
const store = createStore(reducer, initialState);
Using Store
// Initiate action
store.dispatch({type: 'SOME_ACTION', value: 'EX_VALUE'});
// Called once there is change in state
store.subscribe(() => {
// Do something
});
Reducer Code
// Reducer
formReducer(state, action) => {
switch (action.type) {
case SOME_ACTION:
return Object.assign({}, state, {
value: action.value,
});
default:
return state;
}
}
That's it!
CSS-Tricks
https://css-tricks.com/learning-react-redux/
Wait wut
Isn't it back to MVC?
It's all about the view
data:image/s3,"s3://crabby-images/233a9/233a94df0d0587ee926f817a3e3d68e8ddfdcb46" alt=""
WHAT
WHAT
HOW
WHY
HOW
Example
data:image/s3,"s3://crabby-images/d1ac5/d1ac5671fe0a1c6c268f5ef386b4a76d80bec986" alt=""
Example
Smart vs Dumb
Smart: Describe how things work
- Provide no DOM markup or styles
- Provide application data, do data fetching
- Call Flux actions
- Named *Container by convention
Dumb: Describe how things look
- Have no app dependencies
- Receive only props, providing data and callbacks
- Rarely have own state, when they do, it’s just UI state
- Named anything that’s a UI noun
From https://jaketrent.com/post/smart-dumb-components-react/
Smart vs Dumb
From https://jaketrent.com/post/smart-dumb-components-react/
data:image/s3,"s3://crabby-images/9f7dd/9f7dd946299d1c81376208566c120673104a6a3f" alt=""
Smart vs Dumb
From https://medium.com/@dan_abramov/smart-and-dumb-components-7ca2f9a7c7d0
Better separation of concerns
Better reusability
Presentational components
become app’s “palette”
data:image/s3,"s3://crabby-images/6fc4b/6fc4bfb42ff507499b06fbc7b697595aca8d030d" alt=""
data:image/s3,"s3://crabby-images/eca5b/eca5bd186ab60b023726cfcc4c9b24c5906a3739" alt=""
data:image/s3,"s3://crabby-images/b501d/b501db5c223fc36627b4e9d237d7546ba2c3c66e" alt=""
"I would like to amend this: don't use Redux until you have problems with vanilla React."
Dan Abromov
http://redux.js.org/docs/faq/General.html
React & Redux can be used in many ways
SHOW CASE
React Router
React Visualized
https://bvaughn.github.io/react-virtualized/#/components/Collection
https://bvaughn.github.io/react-virtualized/#/components/Collection
React Storybook
http://airbnb.io/react-dates
Thanks!
@jumbosushi
Redux Crash Course @ OttawaJS
By Atsushi Yamamoto
Redux Crash Course @ OttawaJS
- 2,832