Workshop React
Da web ao app!
@diegocosta
@lucianomlima
Meetup React Salvador #1
data:image/s3,"s3://crabby-images/7739b/7739ba1b35f52a03ee9f09425fc224ef240422af" alt=""
data:image/s3,"s3://crabby-images/7739b/7739ba1b35f52a03ee9f09425fc224ef240422af" alt=""
data:image/s3,"s3://crabby-images/e3141/e31413ad676be24d150026550afa268344a6b41a" alt=""
Quem
somos?
Acompanhe em : http://bit.ly/ReactSSAMeetup1
data:image/s3,"s3://crabby-images/9dc2f/9dc2f87090f1659c3a9fabfa4b01d0eb8727dc6b" alt=""
data:image/s3,"s3://crabby-images/3b845/3b845bee90d90786f415e275292f295bdd8389f9" alt=""
Desenvolvedor back-end e mobile
Desenvolvedor front-end e mobile
data:image/s3,"s3://crabby-images/0b939/0b93901a7443c9a11c68ce838a95459a19bcccda" alt=""
data:image/s3,"s3://crabby-images/0a00a/0a00a5b0456d7524fc596e47b34671413f0c18ce" alt=""
React
- JSX
- Props
- State
- Stateless vs Statefull Components
- Ciclo de Vida
É uma biblioteca para construir interfaces
data:image/s3,"s3://crabby-images/13307/13307affd2de250990461443e834cb3684f81f95" alt=""
JSX
const element = (
<div className="shopping-list">
<h1>Shopping List for {props.name}</h1>
<ul>
<li>Instagram</li>
<li>WhatsApp</li>
<li>Oculus</li>
</ul>
</div>
);
const element = React.createElement(
"div",
{ className: "shopping-list" },
React.createElement("h1", null, "Shopping List for ", props.name),
React.createElement(
"ul",
null,
React.createElement("li", null, "Instagram"),
React.createElement("li", null, "WhatsApp"),
React.createElement("li", null, "Oculus")
)
);
Props
const Avatar = props => (
<div>
<img className={"avatar"} src={props.url} alt={props.description} />
<p>Olá, {props.user.name}</p>
</div>
);
Avatar.propTypes = {
url: PropTypes.string,
description: PropTypes.string.isRequired,
user: PropTypes.shape({
name: PropTypes.string
}).isRequired
};
Avatar.defaultProps = {
url: 'https://editorasanar.com.br/avatar.png'
};
// Em outro local...
<Avatar
user={user}
url={'http://api.dominio.com/imagem.png'}
description={`Foto de ${user.name}`} />
State
class Clock extends React.Component {
state = {date: new Date()};
componentDidMount() {
this.timerID = setInterval(this.tick, 1000);
}
componentWillUnmount() {
clearInterval(this.timerID);
}
tick = () => {
this.setState({ date: new Date() });
}
render() {
return (
<div>
<h1>Olá, React!</h1>
<h2>Agora são {this.state.date.toLocaleTimeString()}.</h2>
</div>
);
}
}
State
// Errado
this.state.comment = 'Hello';
// Correto
this.setState({
comment: 'Hello'
});
Não se deve mudar o state diretamente
State
// Errado
this.setState({
counter: this.state.counter + this.props.increment,
});
// Correto
this.setState(function(prevState, props) {
return {
counter: prevState.counter + props.increment
};
});
O state pode ser atualizado de forma async
Stateless vs Statefull
Componentes
// Stateless ES5
function Welcome(props) {
return <h1>Hello, { props.name }</h1>;
}
// Stateless ES6+
const Welcome = props => <h1>Hello, { props.name }</h1>;
// ES6 Class syntax
class Welcome extends React.Component {
render() {
return <h1>Hello, {this.props.name}</h1>;
}
}
Ciclo de vida
Montagem (mounting)
- constructor( )
- componentWillMount( ) *
- render( )
- componentDidMount( )
Ciclo de vida
Atualização (updating)
- componentWillReceiveProps( ) *
- shouldComponentUpdate( )
- componentWillUpdate( ) *
- render( )
- componentDidUpdate( )
Ciclo de vida
Desmontagem (unmounting)
- componentWillUnmount( )
Tratamento de Erros
- componentDidCatch( )
Outras APIs
- setState( )
- forceUpdate( )
App React Web
npx create-react-app meu-app
cd meu-app
npm start
Criando a primeira aplicação
Instalando o ambiente
- node
- npm 5.2.0+
- seu editor de texto preferido
Componentes
import React from 'react';
import {
FlatList,
Modal,
Platform,
Text,
View
} from 'react-native';
Diferenças entre
ReactJS e React Native
Diferenças entre
ReactJS e React Native
CSS Web
.filter {
margin: 0;
padding: 0;
font-family: sans-serif;
color: #47525E;
}
.header {
min-height: 65px;
background: #fff;
padding: 10px;
}
{
filter: {
margin: 0,
padding: 0,
fontFamily: 'sans-serif',
color: '#47525E'
},
header: {
minHeight: 65,
background: '#fff',
padding: 10
}
}
CSS React Native
data:image/s3,"s3://crabby-images/5d7e8/5d7e860aeac587cc9d03245c764f44165e19df26" alt=""
App React Native
create-react-native-app MeuApp
cd MeuApp
npm start
Criando o primeiro aplicativo
Instalando o ambiente
- node
- npm 5.2.0+
- seu editor de texto preferido
npm install -g create-react-native-app
data:image/s3,"s3://crabby-images/fb902/fb902ab921e57a6ebe5f8e21d61009202119d469" alt=""
App React Native
- watchman
- JDK8+
- Android Studio
- Xcode (MacOS)
npm run android
npm run ios
Testando o aplicativo em um simulador
Testando o aplicativo em um dispositivo real
- instale em seu dispositivo o aplicativo Expo client
- esteja conectado na mesma rede
- use Expo client para ler o QRCode no terminal
data:image/s3,"s3://crabby-images/fb902/fb902ab921e57a6ebe5f8e21d61009202119d469" alt=""
App React Native
react-native init MeuApp
cd MeuApp
npm start
Criando o primeiro aplicativo
Instalando o ambiente
- node
- npm / yarn
- watchman
- JDK8+
- Android Studio
- Xcode (MacOS)
- seu editor de texto preferido
npm install -g react-native-cli
data:image/s3,"s3://crabby-images/be558/be558fc79ad8751b6d32d71ec4384c4f8f3c4a80" alt=""
App React Native
react-native run-android
react-native run-ios
Testando o aplicativo
data:image/s3,"s3://crabby-images/be558/be558fc79ad8751b6d32d71ec4384c4f8f3c4a80" alt=""
@ReactSSA
data:image/s3,"s3://crabby-images/d4b45/d4b45c0e3701ca5c91a494181c8fd72167210b05" alt=""
https://github.com/ReactSSA/meetup1-web
https://github.com/ReactSSA/meetup1-app
https://github.com/ReactSSA
http://react.salvador.br
Ecossistema React
data:image/s3,"s3://crabby-images/20c0e/20c0e3d9fa97b4d82c78e9b33cb93bf325d1042b" alt=""
data:image/s3,"s3://crabby-images/b87c8/b87c8079535af2af8ef2c1078643b15939b68e48" alt=""
data:image/s3,"s3://crabby-images/b032d/b032dc48f8045dbcc90a1fd0eb4e1265510519fc" alt=""
data:image/s3,"s3://crabby-images/586e3/586e3c6d450e47ea6bd7e2d91c515b4d97aa5dcc" alt=""
data:image/s3,"s3://crabby-images/246dd/246ddf5a9b1911b00a54ecf815e7f9809d8cea1d" alt=""
data:image/s3,"s3://crabby-images/d6560/d6560c638f713ac458be4fa82c1fa59c74f40b43" alt=""
data:image/s3,"s3://crabby-images/5c892/5c89206614994bd5dd794438de7ae68bfc043b1a" alt=""
data:image/s3,"s3://crabby-images/7c815/7c815d615ab9a7634f23700ca86080ea99c0d3f7" alt=""
Jest
Redux-Observable
data:image/s3,"s3://crabby-images/84577/845779278bd6fa155589a386d9fef685fd5a7b5f" alt=""
Relay
Obrigado!
Se aprofundando:
- Tutorial do ReactJS
- Tutorial do React Native
- Blog do ReactJS
- Blog/Cursos do Wes Bos
- Blog/Cursos do Tyler McGinnis
- Ciclo de vida de um componente
- Twitter (@dan_abramov, @acdlite, @sedmarkbage, @kentcdodds, @leeb, @brian_d_vaughn, @reactjs)
data:image/s3,"s3://crabby-images/9eef8/9eef8ce94569b223e9f8c8599fbbd695c697df2f" alt=""
Temos Vagas!
@diegocosta
@lucianomlima
data:image/s3,"s3://crabby-images/7739b/7739ba1b35f52a03ee9f09425fc224ef240422af" alt=""
data:image/s3,"s3://crabby-images/7739b/7739ba1b35f52a03ee9f09425fc224ef240422af" alt=""
data:image/s3,"s3://crabby-images/3b845/3b845bee90d90786f415e275292f295bdd8389f9" alt=""
data:image/s3,"s3://crabby-images/9dc2f/9dc2f87090f1659c3a9fabfa4b01d0eb8727dc6b" alt=""
Workshop React: da web ao app!
By Luciano Lima
Workshop React: da web ao app!
Meetup ReactSSA #1 - Um breve resumo sobre React e React Native.
- 1,085