React Native
Getting Started
data:image/s3,"s3://crabby-images/f4867/f4867773ed90c1d26faf5e6bd19ea9e760be4d5a" alt=""
informations
Thomas_Dubois.name
Developer.job
rednet.io.company
head.png
assets
React Native ?
data:image/s3,"s3://crabby-images/b0851/b0851b0832d437006fb3972ff33190a3609977f7" alt=""
data:image/s3,"s3://crabby-images/25a9a/25a9a8231627e5ffbffd18efc52c0dd3d1a59135" alt=""
data:image/s3,"s3://crabby-images/11fd2/11fd26c591d57cc069ddf98fc8897de3aa3e729c" alt=""
Under the hood ?
React Native
PhoneGap / Cordova
Native App
Native App
User
User
JSCore
Bridge
Native API
Layouts
Services
Native API
Layouts
Services
Plugins
Web App
data:image/s3,"s3://crabby-images/4eb1c/4eb1cc89a32728dd2b88ce015a4e73de58028980" alt=""
import React, { Component } from "react";
import { Text, View } from "react-native";
class HelloReactNative extends Component {
render() {
return (
<View>
<Text>
If you like React,
you'll also like React Native.
</Text>
<Text>
Instead of "div" and "span",
you'll use native components
like "View" and "Text".
</Text>
</View>
);
}
}
Primitive and
Components
- <View /> : Standard container (comparable to div)
- <Text /> : Text container
- <TouchableOpacity/> : Render sub-component touchable with opacity effect
- <ScrollView /> : Container allowing scroll if overflow
- <FlatList /> : Optimized component for list rendering
- ...
- Platform : OS information
- StyleSheet : Style helper
- ...
Components
API
import {
View , ScrollView, FlatList, SectionList
} from 'react-native'
View you can scroll
item 1
item 2
item 3
item 4
item 5
item 6
item 7
item 1
item 2
item 3
item 4
item 5
item 6
Section 1
Section 2
import {
Text, TextInput
} from 'react-native'
Text
value
import {
Button, Switch, Slider, ...
} from 'react-native'
data:image/s3,"s3://crabby-images/62d34/62d34cfd3a87a313b06d89b73303858c402abc5d" alt=""
data:image/s3,"s3://crabby-images/c23da/c23dac700e10422fc44d04f452ac9826e1b18bb5" alt=""
data:image/s3,"s3://crabby-images/768ee/768ee0c7626774bb5c3f8e8be1a232769d532fa5" alt=""
data:image/s3,"s3://crabby-images/4f5c8/4f5c8b91b023604e22990323f28e84eaead34b6c" alt=""
data:image/s3,"s3://crabby-images/ac8d7/ac8d7cc40ba52ee46d5d0f6b9bd3948f319550a9" alt=""
data:image/s3,"s3://crabby-images/f2e19/f2e196482226001a1d7dab60f21a6b70a14dca01" alt=""
data:image/s3,"s3://crabby-images/25a9a/25a9a8231627e5ffbffd18efc52c0dd3d1a59135" alt=""
data:image/s3,"s3://crabby-images/11fd2/11fd26c591d57cc069ddf98fc8897de3aa3e729c" alt=""
import {
AppState, AsyncStorage, CameraRoll, Linking, Geolocation, ...
} from 'react-native'
- AppState: Application status listener
- AsyncStorage : Store information on the device
- CameraRoll : Native Camera API
- Geolocation: Native API for position
- Linking : Native API for link opening and deep linking
- ...
Platform Component
& Components
- ActionSheetIOS
- DatePickerIOS
- BackHandler
- PermissionsAndroid
- DatePickerAndroid
- ...
import { Platform } from "react-native";
const {
OS, //android | ios
Version, // 28 | 12
select,
} = Platform;
const style = {
flex: 1,
...select({
ios: {
backgroundColor: 'red',
},
android: {
backgroundColor: 'blue',
},
}),
};
// CustomComponent.ios.js
// CustomComponent.android.js
import CustomComponent from "./CustomComponent"
Styling and
Dimensions
data:image/s3,"s3://crabby-images/4eb1c/4eb1cc89a32728dd2b88ce015a4e73de58028980" alt=""
import React, { Component } from "react";
import { View, StyleSheet } from "react-native";
export default class StyleExample extends Component {
render() {
return (
<View
style={{
flex: 1,
alignItems: "center",
justifyContent: "center",
flexDirection: "row"
}}
>
<View style={styles.firstChild} />
<View style={styles.secondChild} />
</View>
);
}
}
const styles = StyleSheet.create({
firstChild: {
width: 50,
height: 50,
backgroundColor: "powderblue"
},
secondChild: {
width: 100,
height: 50,
backgroundColor: "steelblue"
}
});
StyleSheet and Style
- StyleSheet component is here for performance
- Prop 'style'
- Styling object with camelCase properties
- NO UNIT
- flex specific
Dimensions
import { Dimensions } from "react-native";
const {height, width} = Dimensions.get("window");
- Still no unit
- Change on screen rotation
- Event listener 'change' available
Let's code!
Snack
- No dependencies, it's in the browser!
Dependencies
- React Native API available
- Test on browser or on your device
- Tiers JS libraries availables
- Exportable en projet Expo
Things to know
expo
- Node / npm
- Git
- (OSX) Watchman - Recommended
Dependencies
- Few dependencies
- React Native API available
- Test on your device or on Emulator (Need more dependencies)
- Tiers JS libraries availables
- Your dev environment
Things to know
data:image/s3,"s3://crabby-images/aa198/aa198325c578bfdb7d7b0f2b21a178c8df7fe642" alt=""
% npm install -g expo-cli
//[Installation ... ]
//[Things happening ... ]
% expo init ProjectNamePlaceholder
//[Project creation in progress ... ]
//[Other things here ... ]
//Not actual process footage
react-native
- Node / npm
- (OSX) Watchman - Recommended
- (Windows) Python
- JDK (Android)
- Android Studio / Android SDK (Android)
- XCode (iOS)
Dependencies
- Test on Emulator
- Tiers JS and Native libraries availables
- Your dev environment
- Manage React Native releases
Things to know
data:image/s3,"s3://crabby-images/aa198/aa198325c578bfdb7d7b0f2b21a178c8df7fe642" alt=""
% npm install -g react-native-cli
//[Installation ... ]
//[Things happening ... ]
% react-native init ProjectNamePlaceholder
//[Project creation in progress ... ]
//[Other things here ... ]
//Not actual process footage
Did you say debug ?
Developer Menu
data:image/s3,"s3://crabby-images/27bf4/27bf48eff13a0cb978f015b40b75a7b30b3fbebe" alt=""
data:image/s3,"s3://crabby-images/11fd2/11fd26c591d57cc069ddf98fc8897de3aa3e729c" alt=""
data:image/s3,"s3://crabby-images/25a9a/25a9a8231627e5ffbffd18efc52c0dd3d1a59135" alt=""
⌘ + D
⌘ / Ctrl + M
Browser DevTools
data:image/s3,"s3://crabby-images/14bba/14bba46e5210d416235e6be316e86128e8b2383c" alt=""
React Native Debugger
data:image/s3,"s3://crabby-images/956c4/956c47470680c9828ef57f967ae4985f189f0795" alt=""
That's it!
Experience Feedback
JS / React Based
Performance
Easy to start
...
Some Native Parts
Upgrades
Difference Web / RN
What's next ?
data:image/s3,"s3://crabby-images/0431a/0431a7093e911bbfd44547042ead43b9c192449f" alt=""
Don't miss thoses libraries
data:image/s3,"s3://crabby-images/41bc1/41bc1727ff4fac5363a5f9d26d6f3cba9240cf8e" alt=""
data:image/s3,"s3://crabby-images/eb14c/eb14cf2c6633c5f855ef53335b6f22a021041f34" alt=""
References
Links
React Native Getting Started
By fromwood
React Native Getting Started
- 1,226