devcommerce conference 2016: react para aplicações web e mobile como plataforma de interface
TRANSCRIPT
![Page 1: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/1.jpg)
ReactPara aplicações web e mobilecomo plataforma de interface
@breno_calazansVTEX
![Page 2: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/2.jpg)
Por que estou falando de React?
![Page 3: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/3.jpg)
VTEX é uma plataforma SaaS de e-commerce
![Page 4: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/4.jpg)
![Page 5: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/5.jpg)
Visite nosso estande!Próximo ao restaurante
![Page 6: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/6.jpg)
Como melhorar a construção de interface de lojas?
![Page 7: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/7.jpg)
Tentamos o modo tradicional
![Page 8: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/8.jpg)
Não é possível ter uma experiência ótima sem interações complexas
![Page 9: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/9.jpg)
A VTEX está construindo uma nova plataforma para desenvolver lojas como aplicações web
![Page 10: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/10.jpg)
![Page 11: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/11.jpg)
Breve História das Aplicações Web
![Page 12: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/12.jpg)
Javascript<div>
<h1 id="title"></h1>
</div>
<script>
var title = document.getElementById
('title');
title.innerHTML = 'Olá, mundo!';
</script>
![Page 13: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/13.jpg)
jQuery<div>
<h1 id="title"></h1>
</div>
<script>
$('#title').text('Olá, mundo!');
</script>
![Page 14: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/14.jpg)
Frameworkscom Data Bind
e TemplatesAngular, Ember, Knockout e
Backbone
<div data-bind="template: 'title-
template'">
</div>
<template id="title-template">
<h1 data-bind="text: $title"></h1>
</template>
<script>
var viewModel = { title: '' };
ko.applyBindings(viewModel);
viewModel.title('Olá, mundo!');
</script>
![Page 15: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/15.jpg)
Problemas
![Page 16: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/16.jpg)
Muitos conceitos!Filters, Directives, Services, Controllers,
Transclusion, Factory, Provider, etc…
![Page 17: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/17.jpg)
SEOGoogle
![Page 18: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/18.jpg)
Linguagem de Template
![Page 19: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/19.jpg)
Código Imprevisível
![Page 20: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/20.jpg)
“Na minha época era mais fácil…”
![Page 21: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/21.jpg)
Request
Usuário abre uma página
Servidor Banco
Lê os dados do banco de dados
Servidor
Renderiza um template com os dados
Response
Página HTML
Request
Atende a requisição
![Page 22: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/22.jpg)
(data) => page
![Page 23: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/23.jpg)
O Facebook parou pararepensar as boas práticas
![Page 24: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/24.jpg)
React
![Page 25: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/25.jpg)
Biblioteca Javascript para construção de interfaces
![Page 26: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/26.jpg)
Muitos conceitos
![Page 27: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/27.jpg)
ComponentesMuitos conceitos
![Page 28: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/28.jpg)
Código Imprevisível
![Page 29: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/29.jpg)
(data) => HTMLCódigo Imprevisível
![Page 30: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/30.jpg)
(data) => HTMLCódigo Imprevisível
![Page 31: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/31.jpg)
Linguagem de Template
![Page 32: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/32.jpg)
Tudo é JavascriptLinguagem de Template
![Page 33: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/33.jpg)
Performance
![Page 34: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/34.jpg)
Virtual DOMPerformance
![Page 35: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/35.jpg)
SEO
![Page 36: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/36.jpg)
Renderização Server-sideSEO
![Page 37: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/37.jpg)
“E os designers?”
![Page 38: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/38.jpg)
JSXclass Hello extends React.Component {
render() {
return <h1>Olá Mundo!</h1>;
}
}
JSX
![Page 39: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/39.jpg)
API DeclarativaSQL, Regex e Programação funcional
![Page 40: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/40.jpg)
SELECT * FROM usersWHERE name=”Silva”;
var table = Database.use(‘users’); var users = table.getAll();
var result = filter(users, (user) => { return user.name == “Silva”;});
API Declarativa API Imperativa
![Page 41: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/41.jpg)
Com React você não precisa lidar diretamente com o DOM
![Page 42: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/42.jpg)
Facebook, Netflix, Dropbox, AirBnb, Reddit, PayPal, Khan Academy, Walmart,ESPN, Microsoft, Uber,NFL, Mozilla, Globo
![Page 43: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/43.jpg)
Ressalvas!
![Page 44: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/44.jpg)
React não é bala de prata
![Page 45: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/45.jpg)
Caso você não queira lidar com renderização server-side, use
apenas em áreas logadas
![Page 46: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/46.jpg)
Mobile Apps
![Page 47: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/47.jpg)
Cordova & PhoneGap
![Page 48: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/48.jpg)
Browser● Não tem sistema de gestos● Javascript não tem processos
paralelos● Não tem acesso a capacidades
nativas
![Page 49: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/49.jpg)
O ambiente nativo é muito mais poderoso que o web
![Page 50: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/50.jpg)
Mas tudo vem com um custo...
![Page 51: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/51.jpg)
O ambiente nativo é mais hostil
![Page 52: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/52.jpg)
iOS e AndroidEquipes, ferramentas, projetos e
códigos diferentes
![Page 53: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/53.jpg)
API Imperativa
![Page 54: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/54.jpg)
React?
![Page 55: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/55.jpg)
React foi feito para construir qualquer sistema de interfaces
![Page 56: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/56.jpg)
React Native
![Page 57: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/57.jpg)
É um framework para construção de aplicativos nativos usando
Javascript e React.
![Page 58: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/58.jpg)
Arquitetura multicore
![Page 59: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/59.jpg)
API Declarativa
![Page 60: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/60.jpg)
“Escreva uma vez, rode em qualquer lugar”
![Page 61: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/61.jpg)
“Aprenda uma vez, desenvolva em qualquer lugar”
![Page 62: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/62.jpg)
“Compartilhe quando possível,vá nativo quando necessário”
![Page 63: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/63.jpg)
Compartilhe
● APIs● Ferramentas● Linguagem● Código
Nativo
![Page 64: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/64.jpg)
Compartilhe
● APIs● Ferramentas● Linguagem● Código
Nativo
● Funcionalidades Proprietárias
● Performance● Investimentos
Existentes
![Page 65: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/65.jpg)
Facebook Ads Manager● Experiência nativa● Feito pelo mesmo time● Compartilha 80-95% do código
![Page 66: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/66.jpg)
Concluindo
![Page 67: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/67.jpg)
React mudou a comunidade fundamentalmente
![Page 68: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/68.jpg)
Popular
Github Stars
★ 43,131 React
★ 39,717 jQuery
★ 16,300 Ember
★ 12,540 Angular
![Page 69: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/69.jpg)
Criou um ecossistema
Pacotes no npm
15,202 React
9,915 jQuery
3,682 Ember
7,589 Angular
![Page 70: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/70.jpg)
React- Abstração simples- Fácil de testar- API Declarativa- Desenvolvedores confiantes- Facilita composição- Várias plataformas
![Page 71: DevCommerce Conference 2016: React para aplicações web e mobile como plataforma de interface](https://reader031.vdocuments.mx/reader031/viewer/2022021923/5a6629b87f8b9a214f8b5e01/html5/thumbnails/71.jpg)
Obrigado