Guías de Make it Real
  • Introduction
  • Preparación
    • Conceptos básicos
    • El editor de texto
    • La línea de comandos
    • Git y Github
  • Git
    • Instalación y configuración
    • Conceptos y comandos esenciales
    • Ignorando archivos y carpetas
    • Trabajando con ramas
    • Repositorios remotos
    • Etiquetas
    • Reescribiendo la historia
    • Stashing
    • Github
  • HTML y CSS
    • Introducción a HTML
    • Introducción a CSS
    • Más elementos de HTML
    • Tablas
    • Formularios
    • El modelo de caja en CSS
    • Fondos (backgrounds)
    • Posicionamiento
    • Selectores CSS
    • Bordes, sombras y gradientes
    • Media Queries
    • Unidades en CSS
    • Flexbox
  • Bootstrap 3
    • Primeros pasos
    • Elementos básicos de HTML
    • Componentes
    • La grilla
    • Personalizando Bootstrap
    • Utilizando plantillas
  • Bootstrap 4
    • Primeros pasos
    • Elementos básicos de HTML
    • Componentes
    • La grilla
    • Clases utilitarias
    • Personalizando Bootstrap
  • Ruby
    • Primeros pasos
    • Tipos y operadores
    • Variables y entrada de usuario
    • Condicionales
    • Ciclos
    • Arreglos
    • Más cadenas de texto
    • Hashes
    • Métodos
    • Manipulación de archivos
    • Gemas
  • Programación Orientada a Objetos en Ruby
    • Clases y objetos
    • Métodos y atributos de clase
    • Herencia
    • Módulos
    • Excepciones
  • JavaScript I
    • Primeros pasos
    • Tipos y operadores
    • Variables
    • Condicionales
    • Ciclos
    • Arreglos
    • Más cadenas de texto
    • Funciones
    • Objetos literales
    • Manipulación de archivos
  • JavaScript en el navegador
    • Primeros pasos
    • Manipulando HTML
    • Escuchando eventos
    • Local Storage
    • History API
    • Canvas
    • Notificaciones Web
    • Audio y Video
    • Arrastrar y soltar
    • JSON
    • Realizando peticiones HTTP
  • jQuery
    • Primeros pasos
    • Manipulando HTML
    • Escuchando eventos
    • Plugins
    • Realizando peticiones con AJAX
  • JavaScript II
    • Prototipos
    • Librerías (Node.js)
    • ES6
    • Uso de this (call, apply, bind)
    • Programación funcional
    • Scope, hoisting, closures
    • Programación asincrónica
    • Testing
  • HTTP y Sinatra
    • Primeros pasos con Sinatra
    • El protocolo HTTP
    • Rutas
    • Formularios
    • Cookies y sesión
  • Bases de datos
    • Bases de datos relacionales
    • SQL
    • DDL
    • MongoDB
  • Ruby on Rails I
    • Primeros pasos
    • Arquitectura
    • Rutas
    • Layouts y rendering
    • ActiveRecord - Modelos
    • ActiveRecord - Migraciones
    • ActiveRecord - Validaciones
    • ActiveRecord - Asociaciones
    • ActiveRecord - Scopes
    • ActiveRecord - Callbacks
    • Recursos REST
    • Formularios
    • Autenticación con Devise
    • Sass y Bootstrap
    • Envío de correos
    • Carga de imágenes
    • Seeds
    • Heroku
  • Ruby on Rails II
    • Usando JavaScript (y jQuery) en Rails
    • Testing en Ruby
    • Testing en Rails
    • Creando una Web API
    • Web Sockets
  • Express.js
    • Primeros Pasos
    • El protocolo HTTP
    • Rutas
    • Vistas
    • Middlewares y manejo de errores
    • Formularios
    • Cookies y sesión
  • Express.js II
    • Mongoose
    • Web Sockets
    • Autenticación
    • Envío de correos
    • Cargar imágenes
    • Deployment
    • Testing
    • Creando una Web API
  • React
    • Primeros pasos
    • JSX
    • Componentes
    • Más sobre estado
    • Formularios
    • Peticiones HTTP con Axios
    • React Hooks
    • React Context
    • React Bootstrap
    • React Router
    • Carga de Imágenes
    • Testing
    • Estructura de carpetas
    • Componentes de clase
  • Redux
    • Primeros pasos
    • Action creators
    • Usando la librería react-redux
    • Middlewares
    • Operaciones asincrónicas con redux-thunk
    • Combinando funciones reductoras
    • Testing
    • Redux Tool Kit
  • Algoritmos
    • Describiendo un algoritmo
    • Complejidad (Big-O)
    • Estructuras de datos
    • Recursión
    • Ordenamiento
    • Búsqueda
    • Programación dinámica
  • Python
    • Primeros Pasos
    • Tipos y Variables
    • Funciones
    • Control de Flujo
    • Listas
    • Ciclos
    • Diccionarios, Tuplas y Sets
  • NumPy
    • Primeros Pasos
    • Arreglos
    • Arreglos Multidimensionales
    • Estadística con NumPy
    • Distribución Estadística
  • Pandas
    • Primeros Pasos
    • Inspección y Selección de Datos
    • Modificando Dataframes
    • La Función Lambda
    • Aggregates en Pandas
    • Múltiples Tablas
Powered by GitBook
On this page
  1. JavaScript en el navegador

Arrastrar y soltar

PreviousAudio y VideoNextJSON

Last updated 2 years ago

Esta funcionalidad permite arrastrar un elemento y soltarlo sobre otro elemento.

El primer paso para poder arrastrar un elemento es agregarle el atributo draggable con el valor true:

<div draggable="true"></div>

El siguiente paso es utilizar JavaScript (a través de los eventos que veremos a continuación) para saber cuándo el elemento empieza a ser arrastrado y cuándo es soltado.

Sobre el elemento arrastrado se disparan los siguientes eventos:

  • dragstart: el usuario inició el arrastre del elemento.

  • drag: el usuario está arrastrando el elemento (se dispara cada pocos cientos de milisegundos).

  • dragend: el usuario terminó el arrastre.

Sobre el elemento destino se disparan los siguientes eventos:

  • dragenter: el elemento arrastrado está entrando en la zona de soltado.

  • dragleave: elemento arrastrado está saliendo de la zona de soltado.

  • dragover: el elemento arrastrado está sobre la zona de soltado (se dispara cada pocos cientos de milisegundos)

  • drop: el elemento fue soltado.

Veamos un ejemplo, arrastra la imagen del cuadrado de la izquierda al cuadrado de la derecha:

El primer paso de este ejemplo fue agregarle la propiedad draggable a la imagen:

<img id="logo" src="..." draggable="true">

Como no hay forma de saber cuál elemento es el que se está arrastrando y soltando utilizamos el evento dragstart para guardar el id del elemento en un objeto llamado dataTransfer:

var img = document.querySelector("img")
img.addEventListener("dragstart", function(e) {
  e.dataTransfer.setData("text", this.id)
})

Por último, manejamos el evento drop sobre el cuadrado de la derecha. Para que se dispare el evento drop debemos invocar el método e.preventDefault() sobre los eventos dragenter y dragover (esto es un poco confuso pero así funciona).

var target = document.querySelector(".target")
target.addEventListener("dragenter", function(e) {
  e.preventDefault()
})
target.addEventListener("dragover", function(e) {
  e.preventDefault()
})
target.addEventListener("drop", function(e) {
  e.preventDefault()
  var id = e.dataTransfer.getData("text")
  this.appendChild(document.getElementById(id))
})

Para indicar visualmente que el cuadrado de la derecha es una zona de soltado, podemos crear una nueva clase dotted que muestre un borde de guiones y utilizar los eventos dragenter y dragleave para agregar y remover la clase:

.dotted { border: 1px dashed #333; }
target.addEventListener("dragenter", function(e) {
  e.preventDefault()
  this.classList.add("dotted")
})
target.addEventListener("dragleave", function() {
  this.classList.remove("dotted")
})
target.addEventListener("drop", function(e) {
  // ...
  this.classList.remove("dotted")
})

Lo anterior se puede ver en el siguiente ejemplo:

Nota: La funcionalidad de arrastrar y soltar es bastante básica con JavaScript puro. Sin embargo, si estás utilizando jQuery puedes utilizar que facilita la implementación y agrega funcionalidades como retroalimentación visual y restricciones de movimiento, entre otras.

este plugin de jQuery UI