Introduction to React
@GoyeSays
data:image/s3,"s3://crabby-images/8f689/8f689206b4c42e3b90e0a0edddc41b1de928b49d" alt=""
Carlos Goyeneche
@GoyeSays
https://github.com/Goye
data:image/s3,"s3://crabby-images/11141/111415daf45d5debe064f55bd6e4327a57d69468" alt=""
What is ReactJS?
A library for creating user interfaces
but is more about the same?
https://facebook.github.io/react/
data:image/s3,"s3://crabby-images/083e6/083e6a32b3c22e32aa1e457a72e88628ca2078ba" alt=""
data:image/s3,"s3://crabby-images/0a214/0a214615154251ca038ee3c56e878a38d6db3797" alt=""
+
data:image/s3,"s3://crabby-images/ce66c/ce66cdf24e30bc05a34f1e8946f2cd1885dcbfe3" alt=""
What is ReactJS?
https://facebook.github.io/react/
data:image/s3,"s3://crabby-images/b48d7/b48d7709395a6c0d31cc030c63cd3dd1f4172992" alt=""
What is ReactJS?
https://facebook.github.io/react/
My MVC is better than your MVC
My MVVM is better than your MVC
My MVC is better than you MVVM
What is ReactJS?
Traditional MV* separation of concerns
Model | Controller | ModelView | View |
---|---|---|---|
Data | Display logic | Database data | Templates |
A lot of complexity
What is ReactJS?
https://facebook.github.io/react/
Why do people think that ReactJS is awesome?
https://blog.gyrosco.pe/facebook-just-taught-us-all-how-to-build-websites-51f1e7e996f2
http://jlongster.com/Removing-User-Interface-Complexity,-or-Why-React-is-Awesome
What is ReactJS?
https://facebook.github.io/react/
What is ReactJS?
That's not a new idea...
data:image/s3,"s3://crabby-images/9558a/9558aa57721ddca247ae2faa379d5fb08be1679a" alt=""
- Custom Elements
- Shadow DOM
- HTML Imports
- HTML Templates
The first library based on Web Components was released by Google in 2013
What is ReactJS?
data:image/s3,"s3://crabby-images/44ddf/44ddf335b514e3c3a9b9bfe4e32734d4f7fa181d" alt=""
JSX
What is ReactJS?
Markup with code
data:image/s3,"s3://crabby-images/bcf51/bcf51cc36719e7ab205b7d1ba105a10800b67374" alt=""
What is ReactJS?
Markup with code
Markup and display logic both share the same concern
Pete hunt - Ex-Facebook and Instagram
What is ReactJS?
JSX
data:image/s3,"s3://crabby-images/fcefd/fcefdbc6b1bc328638b0ea04f50c0ef7d477208b" alt=""
What is ReactJS?
JSX
data:image/s3,"s3://crabby-images/08172/08172d8138d269cbfed7c10a13bbaabff68926cd" alt=""
That's ugly but functional
What is ReactJS?
Everything is a component!
data:image/s3,"s3://crabby-images/b66a8/b66a8093d8ca5e04329523d70e378f9360ea635e" alt=""
What is ReactJS?
Virtual DOM
Re-rendering everything on every update:
- Create lightweight description of component UI
- Diff it with the old one
- Compute minimal set of changes to apply to the DOM
What is ReactJS?
Virtual DOM
data:image/s3,"s3://crabby-images/032c4/032c4b128fde26b53a0360fefd5a41f5bba5ec00" alt=""
Imperative vs Declarative programming
Imperative | Declarative |
---|---|
Explicit instructions | Describe the outcome |
The system is stupid, you're smart | The system is smart, you don't care |
Ultimate flexibility | Limited flexibility |
Rackspace
How vs What
What's NPM?
"Easy, fast, robust, and consistent package manager"
https://www.npmjs.com/
What's BabelJS?
https://babeljs.io/
data:image/s3,"s3://crabby-images/b1e45/b1e45b339ba6d84b85064f38a0e1f60cdaaa7a86" alt=""
Use next generation JavaScript, today.
What's WebpackJS?
https://webpack.js.org/
data:image/s3,"s3://crabby-images/3b687/3b687b8ac27fd1a3ac6c64cc47921a09effde645" alt=""
- Bundle your styles
- Bundle your scripts
- Bundle your assets
More cool stuff!
Questions?
https://github.com/Goye
data:image/s3,"s3://crabby-images/37a27/37a2758922756ae218bd159ac4b542c1e938948e" alt=""
Thanks a lot!
https://github.com/Goye
Introduction to React
By Carlos Goyeneche
Introduction to React
Introduction to reactJS
- 217