Até aqui, entendemos profundamente Promises e async/await.
Agora é hora de aplicar isso em um dos usos mais comuns do JavaScript moderno:
consumir dados de uma API usando fetch.
Aqui vamos trabalhar com exemplos reais, erros reais e decisões reais.
🎯 Objetivo da aula
Ao final desta aula, você será capaz de:
- Usar
fetchcomasync/await - Entender o que o
fetchrealmente retorna - Tratar erros de rede corretamente
- Evitar armadilhas comuns
- Ler código assíncrono com confiança
O que é o fetch?
fetch é uma função nativa do JavaScript usada para:
- Fazer requisições HTTP
- Buscar dados de APIs
- Enviar e receber informações
Importante:
fetch NÃO rejeita a Promise em erro HTTP (404, 500). Exemplo: ao se deparar com isso:
fetch("/usuarios/999")
.then(...)
.catch(...)
A intuição é achar que se der erro 404 ou 500, o .catch() será chamado, mas isso NÃO é verdade com o fetch!
O fetch só rejeita a Promise quando ocorre um erro de rede, por exemplo:
- Sem internet
- DNS não resolve
- Servidor fora do ar
- Requisição bloqueada (CORS, etc.)
O que é um erro HTTP para o fetch?
Para o fetch, um erro HTTP como:
- 404 (Not Found)
- 401 (Unauthorized)
- 500 (Internal Server Error)
Ou seja:
- O servidor respondeu
- O protocolo HTTP funcionou
- A requisição chegou e voltou
- Então, para o fetch:
Primeiro exemplo — fetch simples
Vamos buscar dados de uma API pública:
async function buscarUsuario()
{
const resposta = await fetch("https://jsonplaceholder.typicode.com/users/1"); const dados = await resposta.json();
console.log(dados);
}
buscarUsuario();
await espera a resposta HTTP. O segundo await espera a conversão para JSON. Entendendo o que acontece aqui
fetch()retorna uma Promiseawaitpausa a função- O Call Stack é liberado
- A execução continua quando a resposta chega
Tratando erros corretamente
Agora vamos tratar erros do jeito certo.
async function buscarUsuario()
{
try
{
const resposta = await fetch("https://jsonplaceholder.typicode.com/users/999");
if (!resposta.ok)
{
throw new Error("Erro HTTP: " + resposta.status);
}
const dados = await resposta.json();
console.log(dados);
}
catch (erro)
{
console.log("Erro ao buscar usuário:", erro.message);
}
}
buscarUsuario();
console.log("Erro ao buscar usuário: Erro HTTP: 404"); // Saída esperada se o usuário não existir Por que precisamos testar resposta.ok?
Porque:
fetchsó rejeita em erro de rede- 404 e 500 ainda são respostas válidas
- O erro precisa ser tratado manualmente
Exemplo realista — função reutilizável
Um padrão muito comum:
async function fetchJSON(url)
{
const resposta = await fetch(url);
if (!resposta.ok)
{
throw new Error("Erro HTTP: " + resposta.status);
}
return resposta.json();
}
Usando a função:
async function executar()
{
try
{
const usuario = await fetchJSON( "https://jsonplaceholder.typicode.com/users/1" );
console.log(usuario.name); // Saída será o nome do usuário
}
catch (erro)
{
console.log("Erro:", erro.message);
}
}
executar();
Vantagem real do async/await aqui
- Fluxo linear
- Leitura natural
- Tratamento de erro centralizado
- Código mais fácil de manter
Erro comum para evitar
const dados = await fetch(url).json(); // ❌ errado O correto é:
const resposta = await fetch(url); const dados = await resposta.json(); // ✅ Resumo da aula para nunca mais esquecer
fetchretorna uma Promiseawaitpausa apenas a função- Erros HTTP não rejeitam automaticamente
resposta.okdeve ser verificado- async/await deixa o código mais legível
Na próxima aula, vamos integrar async/await com tudo o que vimos sobre Event Loop, microtasks e fluxo de execução — fechando esse capítulo com chave de ouro.
HARDWARE
Entendendo o seu computador
O que há dentro do meu computador?
Existem alguns componentes fundamentais presentes dentro do seu computador e é muito importante que você conheça um pouco sobre eles, seja para argumentar com algum vendedor durante a compra de um novo PC ou para identificar alguma atitude desleal de algum técnico que esteja te passando um orçamento para reparo. Na seção Raio-X aqui do Contém Bits você pode conhecer e entender mais detalhadamente sobre cada componente, ou também pode clicar abaixo no componente que deseja, para conhecê-lo melhor.
Você Sabia?
Ultima Online
Criar um jogo é muito mais complexo do que parece. São milhares, às vezes, milhões de linhas de código. Isso não é exagero! Apenas o jogo Ultima Online possui 6.006.313 linhas de programação, totalizando 25.103.295 palavras
Mario e seu bigode
O personagem Mario só possui bigode porque quando ele foi criado, em 1981, a resolução de tela dos equipamentos disponíveis não permitia que fosse desenhada uma boca, então os desenvolvedores fizeram o grande bigode para contornar essa limitação tecnológica.
Final Fantasy X
O jogo Final Fantasy X para o Sony Playstation 2 vendeu, apenas no dia do seu lançamento, 1.455.732 cópias, estabelecendo um recorde de vendagem para as primeiras 24 horas de um game. Méritos da SquareSoft, que desenvolveu um excelente produto!
Muitos aplicativos
Instalar vários aplicativos com o mesmo propósito, como editores de texto, reprodutores de músicas ou vídeos e até programas antívirus sobrecarregam o seu sistema operacional e ainda ocupam espaço desnecessário em seu HD. Tenha apenas um bom programa para cada função.
Space Invaders
O título Space Invaders, lançado em 1980, fez tanto sucesso em todo o mundo que as pessoas compravam o console Atari apenas para poderem jogá-lo em casa. Saiba mais sobre este incrível título clicando aqui.










