data:image/s3,"s3://crabby-images/fbb00/fbb0018aea75cbe2e8edb02498e42efc00ea7541" alt=""
Building beautiful UI in React Native
By Sanket Sahu
I'm Sanket
Co-founder of GeekyAnts
- React Native Community Contributors
- NativeBase (5,500+ Github stars)
- 80+ in strength
GeekyAnts (NativeBase)
data:image/s3,"s3://crabby-images/b7052/b7052f1cce3fb5627e111e773e497075f4d284b5" alt=""
@sanketsahu
data:image/s3,"s3://crabby-images/16e06/16e063af129fa22b13d568f5b531711e8b92dfeb" alt=""
What is React Native?
data:image/s3,"s3://crabby-images/a6376/a6376f882fdbf50a2d6e625a9f468a5a14063500" alt=""
Why React Native?
- JavaScript
- React
- Cross Platform
- Performance
- Backed by Facebook
- Growing community
Usual Workflow of
Mobile App Development
data:image/s3,"s3://crabby-images/ebd96/ebd9604ad02cb94bed56bf624f75621fc83dc9cf" alt=""
data:image/s3,"s3://crabby-images/485e7/485e7a9d035e1a8146b7b4caf65e9e98e5e5befb" alt=""
Building beautiful UI in React Native
Hard parts of building the UI for Mobile
- Limited Screen Size
- Plethora of Devices to support
- Multiple platforms and their standards
- Google's Material Design
- Apple's Cupertino Design
Let's build a simple "Button Component" in React Native
data:image/s3,"s3://crabby-images/1cf54/1cf54de309eadd038acb9d98558a79aa294dd16b" alt=""
...which would look like this
...which could be used like this
<MyButton title="Awesome Button" />
data:image/s3,"s3://crabby-images/1cf54/1cf54de309eadd038acb9d98558a79aa294dd16b" alt=""
Caption
Box with rounded corners
data:image/s3,"s3://crabby-images/1cf54/1cf54de309eadd038acb9d98558a79aa294dd16b" alt=""
<Text />
<TouchableOpacity />
data:image/s3,"s3://crabby-images/92587/92587a563f132d71e6c3e646edd23bbc5b1bcbca" alt=""
data:image/s3,"s3://crabby-images/18f6a/18f6aa2f0169de1624a38107f48af9c7839919c4" alt=""
data:image/s3,"s3://crabby-images/c6c54/c6c54bfcbf06f3b804d0e4c74999619b60f2443a" alt=""
data:image/s3,"s3://crabby-images/18f6a/18f6aa2f0169de1624a38107f48af9c7839919c4" alt=""
data:image/s3,"s3://crabby-images/1cf54/1cf54de309eadd038acb9d98558a79aa294dd16b" alt=""
data:image/s3,"s3://crabby-images/1ef1e/1ef1e6af167a5a933b4b27444ab96add1186e904" alt=""
data:image/s3,"s3://crabby-images/1cf54/1cf54de309eadd038acb9d98558a79aa294dd16b" alt=""
data:image/s3,"s3://crabby-images/85a01/85a01f7120035ac232051019f642285dc76f5fbf" alt=""
data:image/s3,"s3://crabby-images/8a8b7/8a8b754b54b91ff71d5b34e96a02638bf380231a" alt=""
How to layout?
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
Let's build a simple screen having
- Header
- Content area
- Footer
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
Header
Content
Footer
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
Header
- Fixed height
- Doesn't scroll
- Background color
- White Text
Content
- Fluid height
- Content Scrolls
Footer
- Fixed height
- Doesn't scroll
- Background color
- White Text
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
<View />
- Much like <TouchableOpacity />
- <Text /> for the title
<ScrollView />
- Like <View /> but it's content can scroll
<View />
- Similar to Header
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
StatusBar
- The color has changed
Button
- We can re-use our button component 🙌
data:image/s3,"s3://crabby-images/8dde2/8dde27f7da01b6ad972b8d7b5aa9d7d619a9e67f" alt=""
data:image/s3,"s3://crabby-images/075dc/075dc159a9610c1d0c3eaeb02771aa8e6c22577e" alt=""
data:image/s3,"s3://crabby-images/4287b/4287b2b6155cb5fabcf20e085671cfffeb22a147" alt=""
data:image/s3,"s3://crabby-images/4d6fb/4d6fb83d7556a31ea0c6ed482d362b74e9cc0e4e" alt=""
data:image/s3,"s3://crabby-images/4287b/4287b2b6155cb5fabcf20e085671cfffeb22a147" alt=""
data:image/s3,"s3://crabby-images/4d6fb/4d6fb83d7556a31ea0c6ed482d362b74e9cc0e4e" alt=""
data:image/s3,"s3://crabby-images/4287b/4287b2b6155cb5fabcf20e085671cfffeb22a147" alt=""
data:image/s3,"s3://crabby-images/4d6fb/4d6fb83d7556a31ea0c6ed482d362b74e9cc0e4e" alt=""
But how do we position elements?
(at top, center and bottom)
Welcome Flexbox!
A layout mode inspired from CSS 3
Terminology
Container
- flexDirection
- alignItems
- justifyContent
- ...
Items
- flex
- alignSelf
- aspectRatio
- ...
Flex properties
flexDirection
data:image/s3,"s3://crabby-images/988aa/988aae3f565bd229b944405a725d560099cd3492" alt=""
(for Container)
Couretsy: https://medium.freecodecamp.org/an-animated-guide-to-flexbox-d280cf6afc35
flexDirection
data:image/s3,"s3://crabby-images/ae59c/ae59c170e2adaa2549dcba7defa509859144988d" alt=""
(for Container)
alignItems
data:image/s3,"s3://crabby-images/64c98/64c982ffb29a1ea36bd5352b42297b4b67d5ca9b" alt=""
(for Container)
justifyContent
data:image/s3,"s3://crabby-images/39e8f/39e8f16f395c240761fc0c2e095dde0e3d4a9fdd" alt=""
(for Container)
alignSelf
(for Items)
data:image/s3,"s3://crabby-images/808a2/808a2a6a7f19e4b253413f4c315a091005fa7178" alt=""
flex
(for Items)
data:image/s3,"s3://crabby-images/5ba3d/5ba3d1b67da8ba8cc3318d6eaa696151120f6ef4" alt=""
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
data:image/s3,"s3://crabby-images/894c3/894c302ff40796912578b512f57bc5dd3de09c08" alt=""
data:image/s3,"s3://crabby-images/4287b/4287b2b6155cb5fabcf20e085671cfffeb22a147" alt=""
without flex: 1
with flex: 1
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
data:image/s3,"s3://crabby-images/55f7e/55f7effa3c10ba1737e85bcf3081b7d12b28ccb0" alt=""
data:image/s3,"s3://crabby-images/4287b/4287b2b6155cb5fabcf20e085671cfffeb22a147" alt=""
before
after
data:image/s3,"s3://crabby-images/e899f/e899f2acd95623784b4cf5038fcedac6f2935950" alt=""
data:image/s3,"s3://crabby-images/82c9a/82c9a99bd07b3c39153cda288d3a1e105fa4634e" alt=""
data:image/s3,"s3://crabby-images/d9b05/d9b059f09ce2bf9be26c5909dbed1cb045f41e2f" alt=""
data:image/s3,"s3://crabby-images/35509/35509ab61122ad3fac0be88c65daf647253ca699" alt=""
iOS guidelines
Android guidelines
Platform specific differences
Platform specific differences
data:image/s3,"s3://crabby-images/3523e/3523eec0b13008255fa92b5b9e91840c9ec355b8" alt=""
But the UI needs
more than just
"rectangular blocks"
Icons?
use "react-native-vector-icons"
data:image/s3,"s3://crabby-images/d1166/d116612fd96a782f068b0428b259c7554fc84377" alt=""
data:image/s3,"s3://crabby-images/86c53/86c5332c02b815a8aa152b85c4a9b9d5915417ab" alt=""
Custom Shapes?
use "react-native-svg"
data:image/s3,"s3://crabby-images/7c49f/7c49f5d921b92c5db0b9e8a9dc0f4d117beda29a" alt=""
data:image/s3,"s3://crabby-images/7c49f/7c49f5d921b92c5db0b9e8a9dc0f4d117beda29a" alt=""
data:image/s3,"s3://crabby-images/87954/8795466d385913ec7ce8ef1096cd7c0c72c5165a" alt=""
data:image/s3,"s3://crabby-images/5d6da/5d6da4035d1b1ac30014a5943a634d3ed989d06a" alt=""
data:image/s3,"s3://crabby-images/8bb78/8bb7817bb2034440e9a4919caf2c5faa68fc1640" alt=""
data:image/s3,"s3://crabby-images/51177/51177de30249ef5ec6c68563826a3d0202d984f9" alt=""
data:image/s3,"s3://crabby-images/eb13c/eb13c89eb96c54dcbf5b95d9245c39d249c64fd3" alt=""
data:image/s3,"s3://crabby-images/9b36e/9b36ec19e439fcbc2977d8504982f8e015ee06cc" alt=""
data:image/s3,"s3://crabby-images/3b2a0/3b2a0f2efd736fa2f7c31178d20d3c43de984604" alt=""
and we need Tabs, Cards, Swipper, FAB etc
The need of a generic set of UI components
And that's why we built
data:image/s3,"s3://crabby-images/40cfc/40cfcba4b23847b60001b2087a0670da97b4a180" alt=""
NativeBase
data:image/s3,"s3://crabby-images/881b6/881b6e246180d4b39a58cdd178ac99aed0c07e6c" alt=""
data:image/s3,"s3://crabby-images/01f34/01f34c92f442b3235d823a8c1ac7fbb70f66fb47" alt=""
data:image/s3,"s3://crabby-images/881b6/881b6e246180d4b39a58cdd178ac99aed0c07e6c" alt=""
data:image/s3,"s3://crabby-images/01f34/01f34c92f442b3235d823a8c1ac7fbb70f66fb47" alt=""
data:image/s3,"s3://crabby-images/1418f/1418fdcea2235432c9a316514c2614e3d809761a" alt=""
NativeBase KitchenSink App
data:image/s3,"s3://crabby-images/3e630/3e630c81a04babdbced7d2e0623614b15c81d2a7" alt=""
data:image/s3,"s3://crabby-images/de224/de224eb5fb97718e277bda3fa627821c1c0464b1" alt=""
Takeaways
- Building UI in React Native is very similar to web
- Flexbox is a must to build layouts in React Native
- Platform specific guidelines can't be ignored
- Use libraries like NativeBase to save the development time
@sanketsahu
Follow me?
Thank you!
deck
By sanketgeekyants
deck
- 913