react.js conf & f8
TRANSCRIPT
![Page 1: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/1.jpg)
KKbOX
React.JS Conf & F8Randy Lien
![Page 2: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/2.jpg)
KKbOX
Agenda
• Introduce React.js Conf
• Highlight
• Conclusion
• FAQ
![Page 3: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/3.jpg)
KKbOX
Introduce React.js Conf
![Page 4: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/4.jpg)
KKbOX
![Page 5: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/5.jpg)
KKbOX
![Page 6: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/6.jpg)
KKbOX
![Page 7: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/7.jpg)
KKbOX
![Page 8: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/8.jpg)
KKbOX
![Page 9: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/9.jpg)
KKbOX
![Page 10: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/10.jpg)
KKbOX
![Page 11: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/11.jpg)
KKbOX
![Page 12: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/12.jpg)
KKbOX
Introduction
• 2015/1/28 ~ 1/29 @Facebook HQ, CA
• 160~
• 18 sessions + 2 panels
• Tickets sold out in 1 minutes (3 waves)
![Page 13: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/13.jpg)
KKbOX
Highlight
![Page 14: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/14.jpg)
KKbOX
Highlight
• Performance
• Flux & Relay
• Component Communication
• React Native
![Page 15: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/15.jpg)
KKbOX
Performance
![Page 16: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/16.jpg)
KKbOX
The Keys to React Performance
• How to render
• When to render
![Page 17: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/17.jpg)
KKbOX
Solutions
• Virtual DOM
• Optimistic re-rendering
![Page 18: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/18.jpg)
KKbOX
Optimistic re-rendering• Pure Component (prop, state)
• Immutable data
• shouldComponentUpdate
• Only re-render when value is changed
• PureRenderMixin
![Page 19: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/19.jpg)
KKbOX
Why Immutable?
• Immutable data is no side effect!
• Shared mutable state is the root of all evil - Pete Hunt
![Page 20: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/20.jpg)
KKbOX
![Page 21: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/21.jpg)
KKbOX
Why Immutable? (cont.)
• The reason why Om is faster than React
• Data or Value is immutable in Clojure
• Immutable + PureRenderMixin
![Page 22: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/22.jpg)
KKbOX
facebook.github.io/immutable-js
![Page 23: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/23.jpg)
KKbOX
Immutable.js
• It Implements immutable data structure in JavaScript
• Use the same algorithm with Clojure
![Page 24: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/24.jpg)
KKbOX
PureRenderMixin implementationSimple but efficient
![Page 25: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/25.jpg)
KKbOX
Flux & Relay
![Page 26: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/26.jpg)
KKbOX
Flux & Relay
• Flux is an architecture
• Relay is designed for solving data fetching problem
![Page 27: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/27.jpg)
KKbOX
Flux
• Unidirectional data flow
• Easy to debug
• It’s more of a pattern rather than a formal framework
![Page 28: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/28.jpg)
KKbOX
Flux
![Page 29: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/29.jpg)
KKbOX
Relay
• Relay is designed for solving data fetching problem
• Efficient
• Cache
• GraphQL
![Page 30: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/30.jpg)
KKbOX
Relay Architecture
![Page 31: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/31.jpg)
KKbOX
RelayContainer & Relay Store
![Page 32: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/32.jpg)
KKbOX
Props coupling
![Page 33: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/33.jpg)
KKbOX
![Page 34: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/34.jpg)
KKbOX
Only modify 1 component
![Page 35: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/35.jpg)
KKbOX
![Page 36: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/36.jpg)
KKbOX
Component Communication
![Page 37: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/37.jpg)
KKbOX
Component Communication
• It is a general problem
• Two scenarios
• Parent & Child
• No relationship
![Page 38: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/38.jpg)
KKbOX
Parent & Child
• Pass props
• Use Callbacks
![Page 39: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/39.jpg)
KKbOX
No Relationship• Global event system
• Flux
• Codecademy
• Adapter (broadcast)
• Channel (JS-CSP)
![Page 40: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/40.jpg)
KKbOX
Adaptor
![Page 41: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/41.jpg)
KKbOX
React Native
![Page 42: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/42.jpg)
KKbOX
When ?
![Page 43: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/43.jpg)
KKbOX
The reason to go native
![Page 44: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/44.jpg)
KKbOX
React Native• No WebView, it uses JavaScript to control native UI.
• JavaScriptCore
• 3 pillars
• Touch Handling
• Native Components
• Style & Layout
• Reimplement Flex Box.
![Page 45: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/45.jpg)
KKbOX
Benefits
![Page 46: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/46.jpg)
KKbOX
Access to Platform ComponentsDifferent platforms have their own behaviours and styles
![Page 47: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/47.jpg)
KKbOX
Instant UI change
![Page 48: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/48.jpg)
KKbOX
Show errors on your face
![Page 49: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/49.jpg)
KKbOX
Hard to figure out
![Page 50: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/50.jpg)
KKbOX
Get benefits from existing solution
![Page 51: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/51.jpg)
KKbOX
ComponentKit
![Page 52: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/52.jpg)
KKbOX
Declarative
![Page 53: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/53.jpg)
KKbOX
Same idea
![Page 54: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/54.jpg)
KKbOX
The same conceptideally…
![Page 55: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/55.jpg)
KKbOX
facebook Ads ManagerReact Native + Flux + Relay
![Page 56: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/56.jpg)
KKbOX
facebook GroupsReact Native + Native Objective-C
![Page 58: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/58.jpg)
KKbOX
nuclide.ioImplement on top of Atom
![Page 59: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/59.jpg)
KKbOX
Conclusion
![Page 60: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/60.jpg)
KKbOX
Conclusion• Learn once, write anywhere
• React makes reusable components possible
• Look forward to Flux & Relay + GraphQL
• Tooling
• nuclide
• Jest
![Page 61: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/61.jpg)
KKbOX
Conclusion (cont.)
• React Native is amazing but you still need to learn how native (Android/iOS) works
• Embrace Immutable data structure to reduce complexity
• It is time to use ES6 & ES2015
• Functional Programming is hot
• immutable data structure & functions composition
• #clojure
![Page 62: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/62.jpg)
KKbOX
Trending
• React-inspired View - ComponentKit
• Flux architecture in Server side or App
• Functional Programming
![Page 63: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/63.jpg)
KKbOX
Functional Programming• Operates on streaming and abstracts your behaviours
• Clojure
• LISP
• Immutable data structure
• ClojureScript
• #clojure
![Page 64: React.JS Conf & F8](https://reader034.vdocuments.site/reader034/viewer/2022052307/55ab0d171a28aba30c8b4764/html5/thumbnails/64.jpg)
KKbOX
FAQ