ݺߣ

ݺߣShare a Scribd company logo
REACT NATIVE
Internals
@tadeuzagallo #reactamsterdam
ABOUT Me
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
WHAT HAPPENS WHEN
YOU TYPE A URL INTO YOUR BROWSER
AND PRESS ENTER?
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
What HAPPENS WHEN YOU
RUN A React Native APP?
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
? No WebView
? No HTML
? No CSS
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
import React, {
Component,
} from 'react';
import {
AppRegistry,
Text,
} from 'react-native';
class SampleApp extends Component {
render() {
return (
<Text style={{ margin: 40 }}>
Hello, World!
</Text>
);
}
}
AppRegistry.registerComponent('SampleApp', () => SampleApp);
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@implementation MyNativeModule
RCT_EXPORT_MODULE()
@end
@tadeuzagallo #reactamsterdam
@implementation MyNativeModule
+ (NSString *)moduleName { return @""; }
+ (void)load { RCTRegisterModule(self); }
@end
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
{
"remoteModuleConfig":[
// [ $moduleName, $exportedConstants:{}? $methods:[]?, $asyncIndexes:[]? ]
["RCTStatusBarManager",["getHeight","setStyle","setHidden","setNetworkActivityIndicatorVisible"]],
["RCTSourceCode",{"scriptURL":"http://localhost:8081/index.ios.bundle?platform=ios&dev=true"},["getScriptText"],[0]],
["RCTAlertManager",["alertWithArgs"]],
["RCTExceptionsManager",["reportSoftException","reportFatalException","updateExceptionMessage","reportUnhandledException"]],
// ...
]
}
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
VM
Basics
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
// import React, {
// Component,
// } from 'react';
//
// import {
// AppRegistry,
// Text,
TouchableHighlight,
// } from 'react-native';
//
// class SampleApp extends Component {
onPress() {
alert('Hello, World!');
}
// render() {
// return (
<TouchableHighlight style={{ margin: 40 }} onPress={this.onPress}>
<Text>
Button
</Text>
</TouchableHighlight>;
// );
// }
// }
//
// AppRegistry.registerComponent('SampleApp', () => SampleApp);
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
class SampleApp extends Component {
onPress() {
-> alert('Hello, World!');
}
...
}
@tadeuzagallo #reactamsterdam
if (Platform.OS === 'ios') {
AlertIOS.alert(title, message, buttons);
} else if (Platform.OS === 'android') {
AlertAndroid.alert(title, message, buttons);
}
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
// import React, {
// Component,
// } from 'react';
//
// import {
// AppRegistry,
// Text,
// TouchableHighlight,
// } from 'react-native';
//
// class SampleApp extends Component {
// onPress() {
Alert.alert('Hello, World!', 'Press ok to alert again', [
{ text: 'Ok', onPress() { alert('Ok!') } },
{ text: 'Cancel', onPress() { alert('Cancel') } },
]);
// }
// render() {
// return (
// <TouchableHighlight style={{ margin: 40 }} onPress={this.onPress}>
// <Text>
// Button
// </Text>
// </TouchableHighlight>;
// );
// }
// }
//
// AppRegistry.registerComponent('SampleApp', () => SampleApp);
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
@tadeuzagallo #reactamsterdam
Thank you
@tadeuzagallo #reactamsterdam

More Related Content

Viewers also liked (20)

JavaScript, React Native and Performance at react-europe 2016
JavaScript, React Native and Performance at react-europe 2016JavaScript, React Native and Performance at react-europe 2016
JavaScript, React Native and Performance at react-europe 2016
Tadeu Zagallo
?
React native - What, Why, How?
React native - What, Why, How?React native - What, Why, How?
React native - What, Why, How?
Teerasej Jiraphatchandej
?
A tour of React Native
A tour of React NativeA tour of React Native
A tour of React Native
Tadeu Zagallo
?
Meetup React NativeMeetup React Native
Meetup React Native
Nurielly Caroline Brizola
?
Getting Started with React Native (and should I use it at all?)
Getting Started with React Native (and should I use it at all?)Getting Started with React Native (and should I use it at all?)
Getting Started with React Native (and should I use it at all?)
Devin Abbott
?
React native sharing
React native sharingReact native sharing
React native sharing
Sam Lee
?
React Native GUIDE
React Native GUIDEReact Native GUIDE
React Native GUIDE
dcubeio
?
Intro to react native
Intro to react nativeIntro to react native
Intro to react native
ModusJesus
?
React Native Introduction: Making Real iOS and Android Mobile App By JavaScript
React Native Introduction: Making Real iOS and Android Mobile App By JavaScriptReact Native Introduction: Making Real iOS and Android Mobile App By JavaScript
React Native Introduction: Making Real iOS and Android Mobile App By JavaScript
Kobkrit Viriyayudhakorn
?
An Overview of the React Ecosystem
An Overview of the React EcosystemAn Overview of the React Ecosystem
An Overview of the React Ecosystem
FITC
?
React Native T
React Native TReact Native T
React Native T
Seiichi Okumiya
?
Intro To React Native
Intro To React NativeIntro To React Native
Intro To React Native
FITC
?
What's This React Native Thing I Keep Hearing About?
What's This React Native Thing I Keep Hearing About?What's This React Native Thing I Keep Hearing About?
What's This React Native Thing I Keep Hearing About?
Evan Stone
?
ݧѧէܧ ܧէ ҧѧ٧֧
ݧѧէܧ ܧէ  ҧѧ٧֧ݧѧէܧ ܧէ  ҧѧ٧֧
ݧѧէܧ ܧէ ҧѧ٧֧
ߧ ӧѧݧ
?
Flux and React.js
Flux and React.jsFlux and React.js
Flux and React.js
sara stanford
?
Mobile Day - React Native
Mobile Day - React NativeMobile Day - React Native
Mobile Day - React Native
Software Guru
?
MERN Presentation, January 2015
MERN Presentation, January 2015MERN Presentation, January 2015
MERN Presentation, January 2015
Barry Dyck
?
GraphQL - APIs mais robustas e flexveisGraphQL - APIs mais robustas e flexveis
GraphQL - APIs mais robustas e flexveis
Bruno Lemos
?
React Native in Production
React Native in ProductionReact Native in Production
React Native in Production
Seokjun Kim
?
W3CTechreactר-React Native ̽
W3CTechreactר-React Native ̽W3CTechreactר-React Native ̽
W3CTechreactר-React Native ̽
ŵŶ
?
JavaScript, React Native and Performance at react-europe 2016
JavaScript, React Native and Performance at react-europe 2016JavaScript, React Native and Performance at react-europe 2016
JavaScript, React Native and Performance at react-europe 2016
Tadeu Zagallo
?
Meetup React NativeMeetup React Native
Meetup React Native
Nurielly Caroline Brizola
?
Getting Started with React Native (and should I use it at all?)
Getting Started with React Native (and should I use it at all?)Getting Started with React Native (and should I use it at all?)
Getting Started with React Native (and should I use it at all?)
Devin Abbott
?
React native sharing
React native sharingReact native sharing
React native sharing
Sam Lee
?
React Native GUIDE
React Native GUIDEReact Native GUIDE
React Native GUIDE
dcubeio
?
Intro to react native
Intro to react nativeIntro to react native
Intro to react native
ModusJesus
?
React Native Introduction: Making Real iOS and Android Mobile App By JavaScript
React Native Introduction: Making Real iOS and Android Mobile App By JavaScriptReact Native Introduction: Making Real iOS and Android Mobile App By JavaScript
React Native Introduction: Making Real iOS and Android Mobile App By JavaScript
Kobkrit Viriyayudhakorn
?
An Overview of the React Ecosystem
An Overview of the React EcosystemAn Overview of the React Ecosystem
An Overview of the React Ecosystem
FITC
?
Intro To React Native
Intro To React NativeIntro To React Native
Intro To React Native
FITC
?
What's This React Native Thing I Keep Hearing About?
What's This React Native Thing I Keep Hearing About?What's This React Native Thing I Keep Hearing About?
What's This React Native Thing I Keep Hearing About?
Evan Stone
?
ݧѧէܧ ܧէ ҧѧ٧֧
ݧѧէܧ ܧէ  ҧѧ٧֧ݧѧէܧ ܧէ  ҧѧ٧֧
ݧѧէܧ ܧէ ҧѧ٧֧
ߧ ӧѧݧ
?
Mobile Day - React Native
Mobile Day - React NativeMobile Day - React Native
Mobile Day - React Native
Software Guru
?
MERN Presentation, January 2015
MERN Presentation, January 2015MERN Presentation, January 2015
MERN Presentation, January 2015
Barry Dyck
?
GraphQL - APIs mais robustas e flexveisGraphQL - APIs mais robustas e flexveis
GraphQL - APIs mais robustas e flexveis
Bruno Lemos
?
React Native in Production
React Native in ProductionReact Native in Production
React Native in Production
Seokjun Kim
?
W3CTechreactר-React Native ̽
W3CTechreactר-React Native ̽W3CTechreactר-React Native ̽
W3CTechreactר-React Native ̽
ŵŶ
?

React Native Internals