My Journey with
Dart & Flutter as a Front-end Engineer
ZHUORAN LI
data:image/s3,"s3://crabby-images/436cc/436cc2446df32cd083773a0321ee54bfb5354807" alt=""
GitHub: @lzhuor
data:image/s3,"s3://crabby-images/b25fc/b25fc8d68d18eb726b4924599bfe6330b1ffb6f5" alt=""
& Why Flutter?
data:image/s3,"s3://crabby-images/bd83b/bd83bcaff64bcc472f12aa7c0696df2326078de9" alt=""
- Hybrid solution with native performance
- The tone of our design is consistent across platforms
- Community and eco-system
🕵️♀️ Preview
data:image/s3,"s3://crabby-images/ef582/ef5827b0e677d8aa9d1ea932e4e3b537e2b8aa13" alt=""
data:image/s3,"s3://crabby-images/ef582/ef5827b0e677d8aa9d1ea932e4e3b537e2b8aa13" alt=""
data:image/s3,"s3://crabby-images/ef582/ef5827b0e677d8aa9d1ea932e4e3b537e2b8aa13" alt=""
data:image/s3,"s3://crabby-images/29554/29554fc6ba9948c33c65e0093674754d60020d8a" alt=""
data:image/s3,"s3://crabby-images/f9eb0/f9eb01bdfe8f57c08fee48184492624ea99e87bf" alt=""
My Journey with Flutter
"Ex"-favourite YouTuber
The TechLead
Languages Worked on:
- JavaScript, TypeScript, Java, Python, Slang (a DSL in a bank)
Styles
- OOP, FP, Rx
Current Stack at Work
- JavaScript, TypeScript, Dart
- React, Redux, Redux-Saga
Hybrid Experience
- React Native (5 months in production)
UI System
React Component
Flutter Widget
- Declarative
- Declarative
data:image/s3,"s3://crabby-images/43153/431530a432ede3a31045322b47a19a70dedc7973" alt=""
Swift UI
React
Flutter
data:image/s3,"s3://crabby-images/7593d/7593d284165acc31b6ca093709d8f9babe1db74a" alt=""
data:image/s3,"s3://crabby-images/3a742/3a742a9c68c3e7fed1a0efe4d5699f2d55ef48bd" alt=""
Component & Widget
- Configuration of the painting result
- "translates" to one or more elements
data:image/s3,"s3://crabby-images/5f56d/5f56dd921b239efe5b4fe4186121979218cbca0d" alt=""
data:image/s3,"s3://crabby-images/966ab/966ab791f7b21eb9209ccd1a166052576191b029" alt=""
ID
UI System
React Component
Flutter Widget
- Declarative
- Declarative
- Render Object
- No "Virtual DOM" or "Bridge"
- Virtual DOM & DOM (Web)
- Virtual Tree & Native Tree (React Native)
data:image/s3,"s3://crabby-images/fac79/fac7908cb2848b54d2198fb75257f100bcb5814e" alt=""
data:image/s3,"s3://crabby-images/22fca/22fca8c51053016d118b76c1e05da169ad6e233b" alt=""
React Native
Flutter
data:image/s3,"s3://crabby-images/ce8ae/ce8ae2b1290eb074d22ceb4ebecc01ce96aaae5d" alt=""
data:image/s3,"s3://crabby-images/151c5/151c55419260454371e39904a662b12ece9032b4" alt=""
data:image/s3,"s3://crabby-images/8aa8d/8aa8d93f6077c3dd3c47cd3055541e73d93359cf" alt=""
data:image/s3,"s3://crabby-images/c8ad1/c8ad1f8042f54d732301c8115e06efadf86152ef" alt=""
React (Web)
React Native (Mobile)
Flutter
data:image/s3,"s3://crabby-images/4f30d/4f30dd6824df81fab1afe80361993b21933a6b08" alt=""
data:image/s3,"s3://crabby-images/ce8ae/ce8ae2b1290eb074d22ceb4ebecc01ce96aaae5d" alt=""
data:image/s3,"s3://crabby-images/ce8ae/ce8ae2b1290eb074d22ceb4ebecc01ce96aaae5d" alt=""
data:image/s3,"s3://crabby-images/151c5/151c55419260454371e39904a662b12ece9032b4" alt=""
React
Flutter
data:image/s3,"s3://crabby-images/ce8ae/ce8ae2b1290eb074d22ceb4ebecc01ce96aaae5d" alt=""
data:image/s3,"s3://crabby-images/151c5/151c55419260454371e39904a662b12ece9032b4" alt=""
data:image/s3,"s3://crabby-images/94c7e/94c7eabb8b88984ae485010ad870120e1eec0d3e" alt=""
data:image/s3,"s3://crabby-images/0527d/0527de7f573ab8c78b7a21c849f8f4f04779ab3a" alt=""
Reconciliation
UI System
React Component
Flutter Widget
- Declarative
- Declarative
- Render Object
- No "Virtual DOM" or "Bridge"
- Life cycle
- Life cycle
- Virtual DOM & DOM (Web)
- Virtual Tree & Native Tree (React Native)
Life cycle
Flutter Widget
React Component
render
componentDidMount
componentDidUpdate
componentWillUnmount
...
this.setState
stateless component
stateful component
build
initState
mounted
didChangeDependencies
dispose
...
this.setState
stateless widget
stateful widget
Before Hooks
Life cycles
addPostFrameCallback*
Flutter Widget
React Component
data:image/s3,"s3://crabby-images/f35e1/f35e1cf468e512c6b2c0d01041dafb5e8a0ae9dd" alt=""
data:image/s3,"s3://crabby-images/f3498/f3498464d501c96479fa40f1ec6d588ce74f5236" alt=""
Life cycle
data:image/s3,"s3://crabby-images/75d8f/75d8f353b98a2ffdb57de60b9040130a23ee2fe4" alt=""
- markNeedsLayout
- markNeedsBuild
- markNeedsPaint
- Selector
- Widget declared with const
- ...
UI System
React Component
Flutter Widget
- Declarative
- Declarative
- Render Object
- No "Virtual DOM" or "Bridge"
- Life cycle
- Life cycle
- CSS (or JSS)
- Flexbox
- MediaQuery
- Position Absolute
- Translate
- @keyframes;
- Layout
- Flexbox
- MediaQuery
- Stack
- Transform
- Tween
- Virtual DOM & DOM (Web)
- Virtual Tree & Native Tree (React Native)
Layout System
Web (CSS) | Flutter |
---|---|
div | Container |
Flexbox | Row, Column, Wrap, Expanded, Flexible, mainAxisAlignment crossAxisAlignment |
margin, padding, vh/vw text-align | Padding, Center, Align, margin, padding |
position: absolute | Stack, Align, Positioned |
transform | Transform |
@keyframes | AnimationController, Tween |
😁
const ShareFormContainer = styled.div`
margin: 3.2rem 0;
display: flex;
align-items: center;
${media.maxWidth.mobile`
margin-bottom: 0;
flex-direction: column;
`};
`
Responsiveness
Web (Media Query)
data:image/s3,"s3://crabby-images/437b1/437b17c6f6b47d4bc8d6b3dd128609cb236fdeec" alt=""
Flutter (Media Query)
data:image/s3,"s3://crabby-images/bc91a/bc91a94ad27205d9cbcb1f268cd9cb08d316c840" alt=""
Demo (Live Coding)
data:image/s3,"s3://crabby-images/0fbbd/0fbbd153666d0077ce5d7f030b5fdee529547876" alt=""
State Management
data:image/s3,"s3://crabby-images/46be8/46be8ab5ab0035b5bd485039a3b73121157099d1" alt=""
React
Flutter
data:image/s3,"s3://crabby-images/70122/701221e3172d7564ce8af1227fd064c1f0b98252" alt=""
Provider
ScopedModel
data:image/s3,"s3://crabby-images/8d504/8d504c94d4990a2c4de15e979779b6a9fd80447c" alt=""
data:image/s3,"s3://crabby-images/fad48/fad48d0669ff96116923aaae98504d5e913f614f" alt=""
Mobx
Redux-Thunk
Redux
<Context />
data:image/s3,"s3://crabby-images/f8279/f8279cc904b56f8d8af61409a86d6ed3849f2bb1" alt=""
data:image/s3,"s3://crabby-images/b31c1/b31c1cd68f5a36fb47f4e69857bd1951e77bd595" alt=""
State Management
data:image/s3,"s3://crabby-images/6574f/6574fb63db5e10e2ba6d7b8fe2281db06e735cd0" alt=""
data:image/s3,"s3://crabby-images/47124/471241b3f036771487af65a63e173be55e373b24" alt=""
Flutter (BLoC)
React (Redux-Saga)
Communication among BLoCs
- Pass BLoC as param
- Service Locator (get_it)
Communication among Sagas
- Pass Saga as param
- actionChannel
Auth
User
State Management
- A bit disappointed by the yield & yield* syntax in Dart
// JavaScript
const result = yield(saga.call, args)
// Dart
const callback = () => { /*...*/ }
yield(saga.call, args, callback)
Statement
Expression
- takeEvery vs takeLatest
data:image/s3,"s3://crabby-images/3e3e9/3e3e9738c77e679e940715feede552162964ed20" alt=""
data:image/s3,"s3://crabby-images/fc29a/fc29a8fb39eb74c1e1e52457c180fcab7281bd0f" alt=""
extension from RxDart
JavaScript, Redux-Saga
Dart, BLoc & RxDart
data:image/s3,"s3://crabby-images/83118/83118b82b9f2746eb3d71b4452f0d4bd30c6fe56" alt=""
Dart
Dart
JavaScript
Internationalisation (React)
- String
- HTML
- React Component
- Templating
data:image/s3,"s3://crabby-images/217af/217afdbe34ba030ca31b563b3830aa85956cfb2e" alt=""
data:image/s3,"s3://crabby-images/a7c98/a7c982247db0155fa5f14c4bfc2624843e27f338" alt=""
plugin
data:image/s3,"s3://crabby-images/15466/154664ddfe1cbf9e17a880eb08f7ca4ac421926e" alt=""
*react-intl as an example
Internationalisation (Dart & Flutter)
data:image/s3,"s3://crabby-images/109d6/109d6f00b4ceaa44d723033617cae089fe354c13" alt=""
en.arb
data:image/s3,"s3://crabby-images/0ec29/0ec2930c33c0314e4b5e87d0f6bbc425ce541110" alt=""
flutter pub run intl_translation:extract_to_arb --output-dir=assets/intl ./lib/**/*.dart
Ready for Production
- CI/CD: CodeMagic.io
- Out-of-the-box build environment
- Signing / Provisioning
- Versioning
- Integration (not so good as Bitrise.io yet)
- Beta Distribution: AppDistribution
- Error Reporting & Tracking
- Crashlytics
- Sentry
- Google Analytics
*Mixpanel official support is not available yet
Thank you :P
-
App: Launching soon!
-
Referral Sign-up via Web App $20 fee credit:
data:image/s3,"s3://crabby-images/bd83b/bd83bcaff64bcc472f12aa7c0696df2326078de9" alt=""
https://endowus.com/invite?code=1XR8V
data:image/s3,"s3://crabby-images/f22d0/f22d03d7cf31b984abb3ce298de3b85fd0a2f76a" alt=""