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?
Mega Man
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.
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!
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.
Final Fantasy X
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!
Muitos aplicativos
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.










