Descomplicando a
Web moderna
@WellsSA
Wellington S. Almeida
- Typescript Fullstack Developer
- CTO & Co-founder at @Envia.io
- Community Manager at @FlutterNation
- Designer, maybe?
-
Speaker? @icarcal - Music? Let's Rock!
@WellsSA
ETEC Everywhere
@WellsSA
Mas afinal, o que raios é a web?
@WellsSA
No nosso caso
@WellsSA
Frontend
Backend
Infraestrutura
Mas melhor que isso!
@WellsSA
A lógica por trás do mercado atual!
Tecnologias
Conceitos
A princípio
@WellsSA
ANTES DE TUDO
@WellsSA
MAS PRIMEIRO
@WellsSA
1. Aproveite a jornada!
@WellsSA
2. Interrompa, interaja, faça perguntas! :D
("Tamo aí pra isso")
@WellsSA
3. Não se preocupe em saber tudo isso!
(Ajuda, mas não é obrigatório!)
@WellsSA
Agooora sim
@WellsSA
Frontend
Backend
Infraestrutura
@WellsSA
O que é ?
Frontend
-
Exibição para o usuário
- Num ambiente controlado (navegador ou aplicativo)
- Web / Mobile / Terminal
@WellsSA
Falando de Web
-
Não interage com o computador (pra existir precisa do browser)
- Não interage com outras abas
@WellsSA
Falando de Mobile
-
Interage com o "computador" (celular) - mas precisa de permissão
- Não interage com outros aplicativos
Tudo que chega pro usuário, ele tem acesso!
(Nada de senha em input hidden!)
@WellsSA
O que é ?
- Responsável por interagir com serviços!
(Bancos de dados, APIs, outros backends)
- Tem acesso ao computador
- Pode escrever arquivos
(TXT, PDF, PNG, XLSX, etc)
- Pode ter chaves de acesso
Backend
@WellsSA
Serviços?
http://localhost:3306
Text
(Processos)
@WellsSA
Serviços
@WellsSA
Serviços
http://localhost:3306
Host
Porta
(Máquina)
@WellsSA
O que é ?
- No nosso exemplo, o computador
- Todo o ambiente onde nossos serviços rodarão
- Como vou subir a máquina que vai rodar meu código? O banco de dados?
Infraestrutura
@WellsSA
Provedores de cloud
- Te permitem criar suas "máquinas" online
-
Oferecem serviços de bancos de
dados, servidores, etc.
@WellsSA
Separado funciona, mas e junto?
www.wellsadev.com
231.69.123.15
(http://)
DNS
Você
Resposta
Requisição
Frontend
Infraestrutura
Infraestrutura
Infraestrutura
Backend
(HTML, CSS, JS)
@WellsSA
Por trás do backend
166.72.122.12
Infraestrutura
Infraestrutura
Backend
231.69.123.15
172.16.124.13
Backend
Infraestrutura
Banco de dados
Requisições (http | ws | ...)
Resposta (JSON)
@WellsSA
O que é JSON?
[
{
nome: "Wellington",
idade: 20,
amigos: ["Kaleo", "Lucas"],
},
{
nome: "Kaleo",
idade: 21,
amigos: ["Lucas", "Wellington"],
},
]
"[{"nome":"Wellington","idade":20,"amigos":["Kaleo","Lucas"]},{"nome":"Kaleo","idade":21,"amigos":["Lucas","Wellington"]}]"
Objeto
X
Texto
(JavaScript Object Notation)
Partindo do básico
"Lá em 1800 e Chicão era jovem" - Correa, Cristiano
@WellsSA
Programação Estruturada
meu programa;
int variável;
String variável2;
begin
# um monte de código
# mais código
# sério, muito código
# mais um pouquinho de código
# já disse que tem código?
# pode acreditar, código mesmo
...
end
@WellsSA
Programação Orientada a Objetos
class Ornitorrinco {
String nome;
int idade;
}
function alimentar(Ornitorrinco o, Alimento b) {
// M A G I A
// mentira, mais código mesmo
}
class Batata extends Alimento {
// Exemplo meramente ilustrativo
// Tipo foto de alimento
}
@WellsSA
ISSO É MUITO ÚTIL
// Antes
[1, 2, 3, 4, 5]
// Depois
[Ornitorrinco, Ornitorrinco, Ornitorrinco, Ornitorrinco]
[
{
nome: 'Zé',
idade: 15,
},
{
nome: 'Zezim',
idade: 3,
},
]
@WellsSA
Programação Funcional
var x = 2;
var y = 3;
var resultado;
function somar() {
resultado = x + y;
}
function causarDiscordia() {
x = x + 10;
}
causarDiscordia();
somar();
const x = 2;
const y = 3;
function somar(x, y) {
return x + y;
}
const resultado = somar(x, y);
Antes
Depois
Stateless / Immutable
@WellsSA
O quê, não como
const meuEmail = 'zezim123@gmail.com';
function recuperarSenha(email) {
// 1. Validar o e-mail
const deuBom = validaEmail(email);
// 2. Se o e-mail estiver certo, pegar os dados do usuário
if(deuBom === true) {
const meuUsuario = procuraUsuarioPorEmail(email);
// 3. Gerar chave de acesso única
const token = gerarToken(meuUsuario.id);
// 4. Preparar mensagem
const mensagem =
'Para alterar sua senha clique em http://meusite.com?auth=' + token;
// 5. Enviar e-mail com a mensagem
const email = enviarEmail(email, mensagem);
}
}
@WellsSA
- A forma com que programamos muda!
- Mas por quê?
Ou seja
Programação Estruturada
Programação Orientada a Objetos
Programação Funcional
@WellsSA
A evolução vem da necessidade!
@WellsSA
E quais as necessidades da web moderna?
@WellsSA
@WellsSA
A magia da evolução
Componentes
Módulos
Containers
Frontend
Backend
Infraestrutura
@WellsSA
Componentes
Frontend
O Frontend é vivo!
- Responsabilidades
- Estados
- Propriedades
ReactJS, Angular JS, VueJS
@WellsSA
@WellsSA
@WellsSA
Antigamente
Servidor
Infraestrutura
Backend
Frontend Web
Resposta (HTML, CSS, JS)
(Browser)
Frontend Mobile
X
@WellsSA
Atualmente
Servidor
Infraestrutura
Backend
Frontend Web
Resposta (JSON)
(Browser)
Frontend Mobile
Resposta (JSON)
@WellsSA
SPA + REST
O Frontend Só é carregado uma vez!
(Single Page Application + REpresentational State Transfer)
O que ele precisar, ele pede pro servidor (Que devolve só os dados)
@WellsSA
Lembram desse modelo?
www.wellsadev.com
231.69.123.15
(http://)
DNS
Você
Resposta
Requisição
Frontend
Infraestrutura
Infraestrutura
Infraestrutura
Backend
(HTML, CSS, JS)
@WellsSA
Agora ele fica assim
www.app.envia.io
(http://)
DNS
Você
Resposta
Requisição
Frontend
Infraestrutura
(HTML, CSS, JS)
231.69.123.15
Infraestrutura
Backend
231.69.123.15
Infraestrutura
Backend
(JSON)
Resposta
Requisição
Infraestrutura
Backend
231.69.123.16
@WellsSA
Profissionalmente falando
@WellsSA
Módulos
Implementações independentes que funcionam separadamente
NodeJS, Python, Spring
Backend
@WellsSA
Serverless
(Sim, SEM SERVIDOR!)
Funções everywhere
"Pay as you go"
@WellsSA
Containers
Docker, Kubernetes, Docker-Compose
Infraestrutura
Então eu preciso saber de tudo isso pra ser dev?
@WellsSA
NÃÃÃÃÃO!!
@WellsSA
@WellsSA
Existem EQUIPES <3
@WellsSA
E dias normais
Então Bora codar!
@WellsSA
Wellington S. Almeida
-
Slides:
https://slides.com/WellsSA - Código: https://github.com/WellsSA
-
Contatos:
https://wellsadev.com/
@WellsSA
Descomplicando a Web Moderna
By Wellington Almeida
Descomplicando a Web Moderna
- 77