React Made Easy
Mafinar Rashid Khan
Panacea Systems Limited
@mafinar
data:image/s3,"s3://crabby-images/a56e8/a56e8c2efcf3a485636ad4dc7446a32c19cf6e9e" alt=""
A JavaScript Library for building User Interfaces
...in a reason-about friendly way
Actually it's a way of thought, more like...
Functional Programming
data:image/s3,"s3://crabby-images/6f956/6f9568444e644c794b1515c99c2457ba9d895805" alt=""
JavaScript
data:image/s3,"s3://crabby-images/f0e45/f0e4516c2292d1d28ba0b936d12eadafc60c63f6" alt=""
So what do I cover here...???
And the list be like...
- The React Way of Thinking
- JSX
- Components and how the fit together
- MobX
- Fun
data:image/s3,"s3://crabby-images/204bb/204bbc6053143172299a2b77a6d0b1ad83b10d9b" alt=""
But before this, let's talk about...
Vending Machines...
data:image/s3,"s3://crabby-images/31efc/31efcc0bc2955ec31860b16afd03b86ac3d4b53a" alt=""
and now some math...
Remember f(x)?
i.e f(x) = 2*x + 1, what's f(1) kinda stuff??
What if f(x) returned HTML?
And your UI was composed of them?
data:image/s3,"s3://crabby-images/bf05f/bf05f465ce2f32d0773a3f094a05741ab113d4d0" alt=""
...so f(10, 20) becomes <F x={10} y={20} where x,y are props, {} captures JS expressions
Your entire app is composed of those...
So How do I do this???
Think Simple!!!
Look at this little guy...
data:image/s3,"s3://crabby-images/95576/95576224cb1cb12e1c8d6ebb6deff64aa1008aeb" alt=""
Let's think about it...
data:image/s3,"s3://crabby-images/607a1/607a11d4e4ddc2c91fdc5dbd9511c2b3531a2987" alt=""
You have UI, and you have State... state changes the UI, UI might trigger state change
Programming by Wishful Thoughts, friends...
data:image/s3,"s3://crabby-images/748ef/748ef08a8a56f25282cc48eeee8be7da41048419" alt=""
Think Backwards... (at times)
First Make This...
class MainPage extends Component {
render() {
return <App>
<NavBar />
<SideBar />
<MainContent />
<Footer />
</App>
}
}
class NavBar extends Component {
render() {
return <Navigation>
<HamburgerMenu onClick={openSideBar} />
<LinkMenu links={[["Home", "/home"], ["Products", "/product"]]} />
<UserBar />
</Navigation>
}
}
Then move on to writing the actual components...
Components
Functional Programming
State Management
Take 1: <Components />
Turtles All the Way...
Was that HTML in JS?
Sorta
class Item extends Component {
render() {
return <li>{this.props.title}</li>
}
}
class List extends Component {
render() {
return <ul>
{this.props.list.map(
(elem, idx) =>
<Item key={idx} title={elem.title} />)}
</ul>
}
}
That was JSX...
Back to the Board...
A Component has...
- Props
- State
- Children
- Life...
Component Lifecycles???
- componentWillMount
- componentDidMount
- componentWillReceiveProps
- shouldComponentUpdate
- componentWillUpdate
- componentDidUpdate
- componentWillUnmount
Oh and one more thing...
data:image/s3,"s3://crabby-images/2aac7/2aac7d4067d8d374c496160239ad107d565a364d" alt=""
Take 2: Functional Programming
Functions as First Class Citizens
You focus on VERBs, not NOUNs
So, it's eat(cat, rat), NOT cat.eat(rat)
data:image/s3,"s3://crabby-images/ef1d1/ef1d19f75927b6f6269c2c5bdbfc06bdc2c64f62" alt=""
...some pointers
- Lambda Calculus
- Higher Order Functions
- Closure
- Pure Functions
Higher Order Functions
- Functions can take functions in
- Functions can return function bodies
- Also called Functor, Functional Form etc
- map, reduce, filter etc.
Closures
- A data structure storing a function
- A function body that has its local variable snapshots remembered per call
- That's how Clojure got its name?
Take 3: State Management
Brace yourselves... Flux MobX
Observables all the way...
How???
- Mark something as `observable`
- Mark your React Component as `observer`
- Change the `observable` via action
- All `observer`-s who were `observing` that `observable` reacts accordingly.
- That simple!
Illustration...
data:image/s3,"s3://crabby-images/adf7d/adf7df816e16511f24c59a0a3beec6ea492571e4" alt=""
class Person {
@observable firstName = "Michel";
@observable lastName = "Weststrate";
@observable nickName;
@computed get fullName() {
return this.firstName + " " + this.lastName;
}
}
const user = new Person();
@observer
class PersonComponent extends Component {
render() {
return <div>
{user.fullName} + ({user.nickName || "-"})
</div>
}
}
setTimeout(() => user.nickName = "mafinar", 5000)
One more example...
import React, {Component} from 'react'
import {observable} from 'mobx'
import {observer} from 'mobx-react'
@observer
class CounterComponent extends Component {
@observable counter = 0
render() {
return <div>
<div onClick={() => ++this.counter}>(+)</div>
<div onClick={() => this.counter = 0}>{this.counter}</div>
<div onClick={() => --this.counter}>(-)</div>
</div>
}
}
Observable makes things reactive
Observer makes containers react to subscribed observables
data:image/s3,"s3://crabby-images/12568/1256833fa564ce6afee55eb1a4afe6a01381f957" alt=""
Will I cover Flux, Redux etc?
No.
Now What???
Friendly Links...
...and that's IT!
Thanks...
React Made Easy
By Mafinar Khan
React Made Easy
My keynote slides for developer's conference 2016
- 1,617