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?
Asteroids
O título Asteroids, do Atari, possui recorde de pontuação há 30 anos. Em 1982 um americano chamado Scott Safran atingiu a marca de 41.336.440. Atualmente ele faz parte de um minúsculo grupo de jogadores que conseguiram manter seus recordes por mais de 30 anos.
Galaxy Game
As primeiras máquinas de fliperama do mundo a utilizarem moedas, chamadas de Galaxy Game, custavam mais de 20 mil dólares para serem produzidas. Saiba mais sobre elas aqui.
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.
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.
Tetris
Desde o seu lançamento, em 1985, o fantástico jogo Tetris vende pelo menos 70 milhões de unidades por ano em todo o mundo! Os dados são oficiais e fornecidos pela THQ, uma das distribuidoras do título.










