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?
Máquina de Pascal
A Máquina de Pascal, criada em 1642 pelo filósofo, físico e matemático francês Blaise Pascal, é reconhecida como o primeiro computador do mundo e ele foi criado com o objetivo de calcular impostos. Saiba mais.
Recorde de patentes
A IBM detém o recorde de patentes em um único ano, atingindo a marca de 4186 registros no ano de 2008. Clique aqui e saiba mais sobre esta gigante do mundo da tecnologia.
Space Invaders
A partida mais longa do clássico Space Invaders durou incríveis 38 horas e 32 minutos e esta façanha foi conseguida por um jogador de apenas 12 anos! O jogo, claro, podia ser pausado para alimentação e descanso, mas ainda assim o recorde, estabelecido no dia 02/09/1980, ainda não foi quebrado. Saiba mais.
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.
Nintendo Wii
Nos primeiros oito dias após o lançamento do console Nintendo Wii foram vendidas 600 mil unidades. Isso equivale a quase um por segundo e estes incríveis números são referentes às vendas apenas nos EUA!










