A Practical Introduction
data:image/s3,"s3://crabby-images/62fe3/62fe354ca9435f84a8b289090eb4b752714e9a26" alt=""
React.js
whomai
data:image/s3,"s3://crabby-images/08323/08323a020930f518eed733d80559c21a87bfa6f2" alt=""
data:image/s3,"s3://crabby-images/7e655/7e6557aa7010b82f1bfc606f9c87d76a05d1c838" alt=""
Proud Linux User!!1
data:image/s3,"s3://crabby-images/7e655/7e6557aa7010b82f1bfc606f9c87d76a05d1c838" alt=""
Proud Linux User!!1
data:image/s3,"s3://crabby-images/9951a/9951a4e5e9c943f133fc4bf0ff6c174b04230944" alt=""
Astronomy Fan!
Sometimes I also write useful software
data:image/s3,"s3://crabby-images/9d457/9d457181065fde7eaad130c647f01b85f7f72f9d" alt=""
data:image/s3,"s3://crabby-images/1df6b/1df6ba982ce3cfabaaf8015bb23ed4d1252d699c" alt=""
What's React?
What's React?
A library
What's React?
A library
For Building UI Components
What's React?
A library
For Building UI Components
data:image/s3,"s3://crabby-images/62fe3/62fe354ca9435f84a8b289090eb4b752714e9a26" alt=""
with a cool logo!
Only 2 Concepts!
Components
Only 2 Concepts!
Components
State Managment
Only 2 Concepts!
&
Components
State Managment
Only 2 Concepts!
data:image/s3,"s3://crabby-images/62fe3/62fe354ca9435f84a8b289090eb4b752714e9a26" alt=""
here's the cool logo again!
&
Components
Let's Talk About
data:image/s3,"s3://crabby-images/ea7ca/ea7ca8753d5319fbe3e8d033a3e6f15962daf03e" alt=""
data:image/s3,"s3://crabby-images/ea7ca/ea7ca8753d5319fbe3e8d033a3e6f15962daf03e" alt=""
data:image/s3,"s3://crabby-images/ea7ca/ea7ca8753d5319fbe3e8d033a3e6f15962daf03e" alt=""
data:image/s3,"s3://crabby-images/ea7ca/ea7ca8753d5319fbe3e8d033a3e6f15962daf03e" alt=""
Logic +
Logic + Structure
Logic + Structure + Style
Logic + Structure + Style
=
Logic + Structure + Style
Component
=
React Component In a Nutshell
React Component In a Nutshell
(with ugly diagrams :P)
React Component In a Nutshell
-> "public" data" , called .props
(with ugly diagrams :P)
React Component In a Nutshell
-> "public" data" , called .props
-> "private" data, called .state
(with ugly diagrams :P)
React Component In a Nutshell
-> "public" data" , called .props
-> "private" data, called .state
-> a render() function
(with ugly diagrams :P)
React Component In a Nutshell
-> "public" data" , called .props
-> "private" data, called .state
-> a render() function
-> life cycle methods (more on that later...)
(with ugly diagrams :P)
React Component In a Nutshell
-> "public" data" , called .props
-> "private" data, called .state
-> a render() function
-> life cycle methods (more on that later...)
(with ugly diagrams :P)
Weird diagram I Know..
React Component In a Nutshell
-> "public" data" , called .props
-> "private" data, called .state
-> a render() function
-> life cycle methods (more on that later...)
(with ugly diagrams :P)
That's better!
data:image/s3,"s3://crabby-images/62fe3/62fe354ca9435f84a8b289090eb4b752714e9a26" alt=""
Code
We will see code later...
Code
Now, That other thing....
State!
State!
Data Changing Over Time Is Hard!
data:image/s3,"s3://crabby-images/ecc99/ecc993422659f30cf2462483035ad543c27010a1" alt=""
data:image/s3,"s3://crabby-images/8a1f0/8a1f0a0ac7999218e382dcae632c3e611725ac79" alt=""
Simple Data Changes
UnitMenuView = Backbone.View.extend({
initialize : function(model) {
model.on("change:visibility", this.onVisibilityChanged);
this.render();
},
onVisibilityChanged : function(visibile) {...},
render : function() { this.$el.html(this.template(this.model))}
})
"Traditional" Backbone View
data:image/s3,"s3://crabby-images/ecc99/ecc993422659f30cf2462483035ad543c27010a1" alt=""
data:image/s3,"s3://crabby-images/8a1f0/8a1f0a0ac7999218e382dcae632c3e611725ac79" alt=""
Simple Data Changes
data:image/s3,"s3://crabby-images/aec30/aec300b59fe9a36185a57e7c3f5e7026ba9371d2" alt=""
UnitMenuView = Backbone.View.extend({
initialize : function(model) {
model.on("change:visibility", this.onVisibilityChanged);
model.on("change:temperature", this.onTemperatureChanged);
this.render();
},
onVisibilityChanged : function(visibile) {...},
onTemperatureChanged : function(temp) {...},
render : function() { this.$el.html(this.template(this.model))}
})
"Traditional" Backbone View
data:image/s3,"s3://crabby-images/40cb2/40cb2985f059bfd030563462c2d73f7843da5045" alt=""
hmmm....
Can we just re-render on any change?
UnitMenuView = Backbone.View.extend({
initialize : function(model) {
model.on("change", this.render);
this.render();
},
render : function() { this.$el.html(this.template(this.model))}
})
Like this?
nope :(
DOM haz our state!!!
data:image/s3,"s3://crabby-images/085e0/085e0bceadf405cc7e99c527e352e332d8f404fe" alt=""
data:image/s3,"s3://crabby-images/c5625/c5625ab12c80902f770fcdc7f7f90f0692c36d00" alt=""
But...
This is how React Works!
render()
render()
is a "pure" function
render()
is a "pure" function
that returns an instance of a react component
render()
is a "pure" function
that returns an instance of a react component
render()
render()
is a "pure" function
that returns an instance of a react component
render()
.state
render()
is a "pure" function
that returns an instance of a react component
render()
.state
.props
But How?!
Virtual DOM
data:image/s3,"s3://crabby-images/c108c/c108c13373847f721ab1562f5abbacb5973f62e0" alt=""
(Nominated for Best Diagram Award!)
Virtual DOM
Basically
Virtual DOM
It's an implementation detail... don't worry about it too much
Basically
Let's See Code
var Hello = React.createClass({
render: function render() {
return React.createElement("div", null,
"Hello ", this.props.message);
}
});
var Hello = React.createClass({
render: function render() {
return React.createElement("div", null,
"Hello ", this.props.message);
}
});
React.createElement(type, props, children);
var Hello = React.createClass({
render: function render() {
return React.createElement("div", null,
"Hello ", this.props.message);
}
});
React.createElement(type, props, children);
var HelloApp = React.createClass({
render: function render() {
return React.createElement(Hello, {message : "blah"});
}
});
Before we look at some examples...
JSX
JSX
Optional DSL with XML like syntax
JSX
<ComponentName prop1={2 + 4} prop2="primitive"> Children here </ComponentName>
Optional DSL with XML like syntax
JSX
<ComponentName prop1={2 + 4} prop2="primitive"> Children here </ComponentName>
Optional DSL with XML like syntax
compiles to:
JSX
<ComponentName prop1={2 + 4} prop2="primitive"> Children here </ComponentName>
Optional DSL with XML like syntax
React.createElement(ComponentName,
{prop1 : 2+4, prop2 : "primitive"},
"children here");
compiles to:
Questions?
react-intro
By Vitali Perchonok
react-intro
- 1,287