Ao longo deste bloco, aprendemos como funcionam os eventos, mouse, teclado e formulários.
Agora vamos fechar com um tipo especial de interação:
arrastar e soltar elementos na interface.
Esse recurso é muito usado em listas, kanbans, uploads e interfaces modernas.
🎯 Objetivo da aula
Ao final desta aula, você será capaz de:
- Entender o conceito de Drag and Drop
- Conhecer os principais eventos envolvidos
- Tornar um elemento arrastável
- Permitir áreas de soltura (drop)
- Criar uma interação simples de arrastar e soltar
O que é Drag and Drop?
Drag and Drop é a capacidade de:
- Arrastar um elemento
- Movê-lo pela tela
- Soltá-lo em outra área
O navegador fornece eventos específicos para isso.
Principais eventos de Drag and Drop
Os eventos mais importantes são:
dragstart→ início do arrastedragend→ fim do arrastedragover→ elemento sendo arrastado sobre uma áreadrop→ elemento solto
Tornando um elemento arrastável
Para permitir que um elemento seja arrastado, usamos o atributo draggable.
<div id="item" draggable="true">Arraste-me</div> Detectando o início do arraste
const item = document.getElementById("item");
item.addEventListener("dragstart", () =>
{
console.log("Arraste inicado");
});
console.log("Arraste iniciado"); // Saída ao começar a arrastar Criando uma área de soltura (drop zone)
HTML:
<div id="zona">Solte aqui</div> Por padrão, o navegador não permite soltar elementos. Precisamos permitir isso com dragover.
const zona = document.getElementById("zona");
zona.addEventListener("dragover", (event) =>
{
event.preventDefault();
});
Soltando o elemento
zona.addEventListener("drop", () =>
{
zona.appendChild(item);
console.log("Elemento solto");
});
console.log("Elemento solto"); // Saída ao soltar o item Fluxo mental do Drag and Drop
- Elemento é marcado como arrastável
dragstartdisparadragoverpermite a solturadropfinaliza a ação
Exemplo simples completo
item.addEventListener("dragstart", () =>
{
item.classList.add("arrastando");
});
zona.addEventListener("dragover", (event) =>
{
event.preventDefault();
});
zona.addEventListener("drop", () =>
{
zona.appendChild(item);
item.classList.remove("arrastando");
});
Limitações e observações
- Drag and Drop nativo é mais limitado no mobile
- Para projetos complexos, existem bibliotecas
- O conceito é mais importante que a API em si
Resumo da aula para nunca mais esquecer
- Drag and Drop permite arrastar e soltar elementos
- Usa eventos específicos do navegador
dragstartinicia o processodragoverpermite a solturadropfinaliza a ação
Com isso, encerramos o bloco de Eventos no JavaScript. Agora você entende eventos como um sistema completo — e não como truques soltos 🚀
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.
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.
River Raid
O épico jogo River Raid, do Atari, foi desenhado e boa parte de sua programação foi feita por uma mulher: Carol Shaw, uma excelente programadora e funcionária da Activision em 1982. Saiba mais sobre a história deste incrível jogo, aqui.
Duck Hunt
Ao completar o nível 99 do jogo Duck Hunt, para Nintendo, o jogo retorna ao primeiro nível, mas um bug impede que se acerte os patos neste recomeço. Este é um exemplo do que é chamado no mundo dos games de "Kill Screen".
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!










