React Native

John Machahuay Giraldo

Acerca de mi

  • Full Stack developer.
  • Inicié haciendo diseños y ahora me dedico al desarrollo web y móvil.
  • Expositor en distintos meetups.

Agenda

  • Aplicaciones híbridas
  • Hablemos de React Native
  • Debugging
  • Ejemplo de demostración
  • Recursos

Aplicaciones híbridas

Aplicaciones híbridas son

  • "mobile web app", un "HTML5 app"
  • Un webView ejecuta la web app
  • Acceso a las APIs nativas
  • Escribe una vez, despliégalo en distintas plataformas
  • Los componentes de UI son HTML con CSS   link

React Native es una extensión de híbrido

React Native

  • Componentes nativos de UI   link
  • Creado y mantenido por Facebook
  • Apps escritos en Javascript
  • Aprende una vez, escribe para distintas plataformas
  • 80% - 90% código compartido

React Native

  • Los sistemas operativos soportados son >= Android 4.1 (API 16) and >= iOS 8.0.
  • No HTML
  • No CSS directamente - Flexbox
  • No WebView

 

<div> == <View>
<p> || <span> == <Text>
<button> == <TouchableHighlight>
<img /> == <Image />
<input /> == <TextInput />

React Native vs React

import React, { Component } from 'react';

class SomeComponent extends Component {
  render () {
    return (
      <div>
        <p>Hello World</p>
      </div>
    )
  }
}

React  (web)

React Native vs React

import React, { Component } from 'react';
import { Text, View } from 'react-native';

class SomeComponent extends Component {
  render () {
    return (
      <View>
        <Text>Hello World</Text>
      </View>
    )
  }
}

React Native (mobile)

React Native - Producción

 

  • Facebook
  • Instagram
  • Discovery
  • Souncloud
  • Airbnb
  • Wix

 

  more apps

Cómo iniciar

  • Install Node
  • brew install watchman
  • brew install flow (optional)
  • npm install -g react-native-cli
  • react-native init DemoApp
  • react-native run-ios
  • react-native run-android

Muéstrame el código

Componentes

class MyComponent extends Component {
  render() {
    return (
      <View style={styles.container}>
        <Text style={styles.welcome}>
          Welcome to React Native!
        </Text>
        <Text style={styles.instructions}>
          To get started, edit index.android.js
        </Text>
        <Text style={styles.instructions}>
          Shake or press menu button for dev menu
        </Text>
      </View>
    );
  }
}

AppRegistry.registerComponent('MyComponent', () => MyComponent);

Estilos

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
});

Peticiones al servidor

fetch('https://myapi.com/endpoint/', {
  method: 'POST',
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue',
  })
});

Componentes

Ejemplo

No se olviden darle un clic en "star" :P

¿Por qué usar React Native?

Apariencia nativa de los componentes 

Rendimiento

Mejor productividad del desarrollador

React Native es extendible

Aprende una vez, escribe para distintas plataformas

Recursos

  • https://www.toptal.com/mobile/comparing-react-native-to-cordova
  • https://developers.soundcloud.com/blog/react-native-at-soundcloud
  • http://mrn.js.org/
  • https://facebook.github.io/react-native/releases/next/docs/getting-started.html#content

Gracias

John Machahuay

React Native webinar

By johnprog

React Native webinar

  • 1,242