Na aula anterior, você conheceu o IndexedDB como uma alternativa mais poderosa ao localStorage.
Agora é hora de ver isso funcionando na prática.
Nesta aula, vamos usar o IndexedDB para salvar e ler dados reais, passo a passo, sem pressa.
🎯 Objetivo da aula
Ao final desta aula, você será capaz de:
- Criar um banco de dados no navegador
- Criar uma store (tabela)
- Salvar objetos no IndexedDB
- Ler dados armazenados
- Entender o fluxo assíncrono do IndexedDB
Antes de começar: modelo mental
Pense no IndexedDB assim:
- Database → banco de dados
- Object Store → tabela
- Registro → linha
Tudo isso rodando dentro do navegador.
1️⃣ Abrindo (ou criando) um banco de dados
O primeiro passo é abrir um banco de dados.
const request = indexedDB.open("agendaDB", 1); Aqui:
"agendaDB"→ nome do banco1→ versão do banco
2️⃣ Criando a estrutura do banco
Se o banco ainda não existir, o evento onupgradeneeded será chamado.
request.onupgradeneeded = function (event) { const db = event.target.result;
db.createObjectStore("compromissos", {
keyPath: "id",
autoIncrement: true
});
};
Isso cria uma store chamada compromissos, semelhante a uma tabela.
3️⃣ Conexão bem-sucedida
request.onsuccess = function (event)
{
const db = event.target.result; console.log("Banco aberto com sucesso");
}; console.log("Banco aberto com sucesso"); // Saída esperada no console 4️⃣ Salvando dados no IndexedDB
Agora vamos salvar um compromisso no banco.
function salvarCompromisso(db, texto)
{
const transaction = db.transaction("compromissos", "readwrite");
const store = transaction.objectStore("compromissos");
store.add({ descricao: texto });
}
Chamando a função:
salvarCompromisso(db, "Estudar IndexedDB"); 5️⃣ Lendo dados do IndexedDB
Agora vamos buscar todos os compromissos salvos.
function listarCompromissos(db)
{
const transaction = db.transaction("compromissos", "readonly");
const store = transaction.objectStore("compromissos");
const request = store.getAll();
request.onsuccess = function ()
{
console.log(request.result);
};
}
listarCompromissos(db); // Saída será um array de objetos salvos 6️⃣ Observando os dados no navegador
Você pode visualizar o IndexedDB no DevTools:
- Ctrl + Shift + I
- Aba Application
- IndexedDB
Isso ajuda muito no aprendizado.
Comparação mental com localStorage
- localStorage → simples, síncrono
- IndexedDB → estruturado, assíncrono
Agora você já consegue sentir a diferença.
Quando isso começa a fazer sentido?
IndexedDB começa a valer a pena quando:
- Há muitos registros
- Os dados são complexos
- Você precisa trabalhar offline
Resumo da aula para nunca mais esquecer
- IndexedDB é um banco de dados no navegador
- Trabalha de forma assíncrona
- Permite salvar objetos diretamente
- É ideal para aplicações offline
- É a base para PWAs avançados
Na próxima aula, vamos evoluir esse exemplo e integrar IndexedDB com uma interface real e fluxo offline-first.
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?
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.
Nintendo Entertainment System
O console Nintendo Entertainment System (NES), da Nintendo, detém o recorde de videogame mais clonado em todo o mundo. Já foram catalogados mais de 300 aparelhos diferentes capazes de reproduzir seus jogos! Saiba mais sobre ele aqui.
Tetris
O título Tetris detém o recorde de jogo mais adaptado de todos os tempos. No total foram mais de 60 plataformas diferentes que receberam alguma versão do quebra-cabeças criado por Alexey Pajitnov. Conheça mais sobre este incrível jogo clicando aqui.
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
Tomb Raider - O Filme
Considerando todas as adaptações de jogos de videogame para o cinema, a mais bem sucedida foi Lara Croft: Tomb Raider, lançado em 2001 e que faturou 274 milhões de dólares. Ele foi dirigido por Simon West e estrelado pela bela Angelina Jolie.










