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 banco
  • 1 → 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
Não use IndexedDB só porque ele existe. Use quando ele faz sentido.

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.

  • Gabinetes

  • Placas-Mãe

  • Processadores

  • Memória

  • Fontes

  • Drives Ópticos

  • Discos Rígidos

  • SSD

  • Placas de Som

  • Placas de Vídeo

Você Sabia?

A primeira versão do clássico Mega Man, para Nintendo 8 bits, tem seu recorde de pontos estabelecido em 03/11/2006, por David Archey, que cravou 2.396.700 pontos, terminando o jogo.


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!


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.


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!


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.