React Native
data:image/s3,"s3://crabby-images/aa8dd/aa8dd174350128e42bab446c1005d31d9fcccf50" alt=""
Getting started with
data:image/s3,"s3://crabby-images/bb4d8/bb4d8f3a17ddf269dc21bdce2d3a59c42c0e1f5a" alt=""
MICHELE STIEVEN
Web Developer from Bassano del Grappa
RN in produzione
data:image/s3,"s3://crabby-images/aa8dd/aa8dd174350128e42bab446c1005d31d9fcccf50" alt=""
data:image/s3,"s3://crabby-images/f7cf8/f7cf84f5d23c30d28c1b0bda3f3bbb50e9804226" alt=""
data:image/s3,"s3://crabby-images/42cb3/42cb38c7dcba705b0e6b847c026562c511598dba" alt=""
data:image/s3,"s3://crabby-images/46cc5/46cc5a92309c4989d9cc06504f24ac90468d6a90" alt=""
data:image/s3,"s3://crabby-images/0608a/0608a43a7e952e57e0518cb991aa1b675092cfc2" alt=""
data:image/s3,"s3://crabby-images/b64dc/b64dc6c822d6c8310c70f5b463931e4f0c7ddbf5" alt=""
data:image/s3,"s3://crabby-images/8b2c4/8b2c4f5251ca04d6abfa01837e050798eb596e1b" alt=""
data:image/s3,"s3://crabby-images/6b579/6b5793957b6d7c4ec5346cda661974cb0e56df20" alt=""
airbnb
skype
tesla
walmart
ubereats
discord
data:image/s3,"s3://crabby-images/a007f/a007f9629afee102cad7478784af3b1cdaae0d34" alt=""
data:image/s3,"s3://crabby-images/62c80/62c80f7f841c12266ea0596d12397fde155a86e6" alt=""
Java
Objective C, Swift
Nativo
Ibrido
data:image/s3,"s3://crabby-images/56927/56927e51dfcc0134d4f738413b41143367336bfd" alt=""
WebView (HTML, JavaScript, CSS)
data:image/s3,"s3://crabby-images/56927/56927e51dfcc0134d4f738413b41143367336bfd" alt=""
data:image/s3,"s3://crabby-images/12c12/12c12af0bc061e1076017719f6ed55ef4c67b569" alt=""
data:image/s3,"s3://crabby-images/986f5/986f5cd4bf082903853e4c5f658f34fb40441416" alt=""
data:image/s3,"s3://crabby-images/f59bc/f59bcddc971396cc38fdc3233418d89d449f72ef" alt=""
data:image/s3,"s3://crabby-images/ab5bc/ab5bcb3d4fc86c85bc13b37a0751de2ed5b641a7" alt=""
-
No browser (performance)
-
Cross platform
-
JavaScript only
-
Community (plugins)
-
React!
data:image/s3,"s3://crabby-images/dc0b2/dc0b2f8be04e948cdbc517cc291a507be40fe838" alt=""
HTML
CSS
JS
data:image/s3,"s3://crabby-images/631ec/631ec3f8710c12532a50d0e00e653b873f523797" alt=""
JSX!
React
render {
return (
<div>
<h1>Hello world!</h1>
</div>
)
}
React Native
render {
return (
<View>
<Text>Hello world!</Text>
</View>
)
}
import React from 'react';
import { Text } from 'react-native';
const NestedText = (props) => (
<Text>
<Text>
{props.title}
</Text>
<Text>
{props.body}
</Text>
</Text>
)
export default NestedText
const styles = StyleSheet.create({
container: {
borderRadius: 4,
borderWidth: 0.5,
borderColor: '#d6d7da',
},
title: {
fontSize: 19,
fontWeight: 'bold',
}
});
<View style={styles.container}>
<Text style={styles.title}>
Hello World!
</Text>
</View>
FLEXBOX
Componenti
API
Button
Text
Toolbar
DatePicker
Modal
Tabs
Image
Lists
Checkbox
Textbox
Camera
Alerts
Device info
Geo
Settings
Vibration
Toaster
Contacts
Sharing
NATIVE WIDGETS
data:image/s3,"s3://crabby-images/5e793/5e793ac78cea8b05dd982dcb758e56264ebd7522" alt=""
data:image/s3,"s3://crabby-images/f4403/f44033bbac5fad0a83c8c016b64ea65759f5997c" alt=""
data:image/s3,"s3://crabby-images/0afc1/0afc1eed346c6e3d1b4c67c9b2cf16aa912f8d9b" alt=""
data:image/s3,"s3://crabby-images/252fe/252fe231b3243a1f0c23d166d0cdea6b4288db5c" alt=""
data:image/s3,"s3://crabby-images/0cf13/0cf1391fa9582bc00b17e5a75e1b1261c01fc671" alt=""
data:image/s3,"s3://crabby-images/aa8dd/aa8dd174350128e42bab446c1005d31d9fcccf50" alt=""
data:image/s3,"s3://crabby-images/aa8dd/aa8dd174350128e42bab446c1005d31d9fcccf50" alt=""
data:image/s3,"s3://crabby-images/fa52e/fa52ede2d4e2051519f92fd29c993eb9e2c322ea" alt=""
VIRTUAL DOM
data:image/s3,"s3://crabby-images/74efc/74efc28fb3e9a82e95797a7260229f5167867dce" alt=""
Getting started
1° option:
REACT-NATIVE-CLI
2° option:
CREATE-REACT-NATIVE-APP
3° option:
EXPO
data:image/s3,"s3://crabby-images/211ba/211ba324569772aa254ea018ae96ced6472fd79f" alt=""
data:image/s3,"s3://crabby-images/211ba/211ba324569772aa254ea018ae96ced6472fd79f" alt=""
data:image/s3,"s3://crabby-images/211ba/211ba324569772aa254ea018ae96ced6472fd79f" alt=""
REACT-NATIVE CLI
- react-native init myProject
- crea un progetto completo di dipendenze Android/iOS
- per vedere l'app in funzione è necessario avere installato e configurato l'SDK Android o XCode per iOS (solo per Mac)
- è possibile aggiungere librerie contenenti codice nativo
E' LA CLI PIU' COMPLETA
CREATE-REACT-NATIVE-APP
- create-react-native-app myProject
- crea un progetto senza dipendenze native
- per vedere l'app in funzione basta scannerizzare un QRCode da cellulare (o usare un emulatore)
- NON è possibile aggiungere librerie contenenti codice nativo, ma viene fornita una parte di Expo SDK (mappe, social login, accelerometro...)
E' LA CLI CONSIGLIATA DAL TEAM
EXPO?
- Expo è un XDE (Developer Environment)
- Expo è una CLI
- Expo è un SDK (mappe, social login, accelerometro...)
- Expo è un servizio online, gratuito
- Expo viene costantemente citato dalla doc di RN e parte di esso è stata inserita in CRNA
Expo Snack
data:image/s3,"s3://crabby-images/b7bd9/b7bd9f1f16ad6ca5bc5126eb8694b0f9c006ef7f" alt=""
Da dove comincio?
REACT-NATIVE
... oppure CRNA
EXPO (CLIENT O CLI)
EXPO SNACK ?
REACT-NATIVE + ExpoKit
ExpoKIT
- Ancora in fase iniziale
- Passando ad un progetto React-Native perderemmo la possibilità di usare Expo SDK
- Un progetto con ExpoKIT è un progetto react-native con le dipendenze di Expo: possiamo continuare ad usare l'SDK (mappe, social...)
ExpoKIT è tutto l'Expo SDK in mano nostra
Thanks!
SLIDES.COM/MICHELESTIEVEN/REACT-NATIVE-INTRODUCTION
data:image/s3,"s3://crabby-images/b9d04/b9d0432088cbd087ec0080dfcad563dcdc5be820" alt=""
react-native-introduction
By Michele Stieven
react-native-introduction
Breve introduzione allo sviluppo mobile con React Native.
- 172