¿Cómo eliminar la imagen de arrastre (fantasma)?

3 minutos de lectura

Avatar de usuario de Shanmuga Kumar
Shanmuga Kumar

Cómo eliminar la imagen fantasma al arrastrar la imagen. Hemos probado el código, funciona en Firefox y Chrome pero no funciona en Safari. Por favor, alguien que me ayude, ¿cuál es el error de mi código?
https://jsfiddle.net/rajamsr/Lfuq5qb6/

document.addEventListener("dragstart", function( event ) {
      dragged = event.target;
      event.dataTransfer.setDragImage(dragged, 11111110, 10);
}, false);

  • este código aquí está saltando mi memoria al 100% cuando empiezo a arrastrar la imagen, ¿se supone que debe hacer eso, y por qué quieres ocultar el arrastre de la imagen?

    – madalinivascu

    29 de julio de 2016 a las 10:12

Puede evitar mostrar la vista previa fantasma mostrando una imagen vacía/transparente:

document.addEventListener("dragstart", function( event ) {
    var img = new Image();
    img.src="";
    event.dataTransfer.setDragImage(img, 0, 0);
}, false);

  • Esto no parece funcionar bien para los navegadores Chromium, todavía muestra un pequeño icono de “globo”.

    – Mlyck

    4 ene a las 14:03

No use el event.target como argumento para setDragImageesto probablemente esté causando los problemas de memoria aquí.

Siempre puede agregar una imagen personalizada, la imagen también podría ser un PNG transparente.

Aquí hay un ejemplo de cómo va eso.

var dragMe = document.getElementById("drag-me"),
    img = new Image();

img.onload = function () {

  dragMe.addEventListener("dragstart", function(e) {

    e.dataTransfer.setDragImage(img, 0, 0);

  }, false);

}

img.src = "http://placehold.it/150/000000/ffffff?text=GHOST";
#drag-me {
  width: 100px;
  height: 100px;
  background-color: black;
  line-height: 100px;
  text-align: center;
}

#drag-me > img {
  vertical-align: middle;
}
<div id="drag-me">
  <img src="https://jsfiddle.net/img/logo.png" draggable="true" />
</div>

Otra opción sería simplemente clonar el elemento del nodo y establecer su visibility a hidden. Pero para que esta opción funcione es necesario agregar el elemento clonado al DOM.

Un ejemplo con el nodo clonado podría verse así. No estoy ocultando el nodo por completo, para que pueda ver lo que está sucediendo.

var dragMe = document.getElementById("drag-me");

dragMe.addEventListener("dragstart", function(e) {

    var clone = this.cloneNode(true);
    clone.style.opacity = 0.1;               // use opacity or
    //clone.style.visibility = "hidden";     // visibility or
    //clone.style.display = "none";          // display rule
    document.body.appendChild(clone);
    e.dataTransfer.setDragImage(clone, 0, 0);
    
}, false);
#drag-me {
  width: 100px;
  height: 100px;
  background-color: black;
  line-height: 100px;
  text-align: center;
}

#drag-me > img {
  vertical-align: middle;
}
<div id="drag-me">
  <img src="https://jsfiddle.net/img/logo.png" draggable="true" />
</div>

Podrías simplemente usar el event.target y colóquelo usando la ventana outerWidth y outerHeight

document.addEventListener("dragstart", function( event ) {
  event.dataTransfer.setDragImage(event.target, window.outerWidth, window.outerHeight);
}, false);

Su código está causando problemas de memoria.

En su lugar, use css para detener el arrastre/selección del usuario, esto funciona en la mayoría de los navegadores, pero parece que hay un error en Firefox que no funciona, así que agregue ondragstart="return false;" a img etiquetas para arreglar esto ver https://jsfiddle.net/Lfuq5qb6/1/

<img class="normal-logo hidden-xs" src="https://stackoverflow.com/questions/38655964/..." alt="logo" ondragstart="return false;"/> 

img{
    user-drag: none; 
    user-select: none;
    -moz-user-select: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    -ms-user-select: none;
}

function removeGhosting(event) {
    if(!(event instanceof MouseEvent)) {
        console.info("Parameters must be of type MouseEvent!")
        return;
    }
    let dragIcon = document.createElement('img');
    dragIcon.src="",
    dragIcon.width = 0;
    dragIcon.height = 0;
    dragIcon.opacity = 0;
    if(event.dataTransfer) {
        event.dataTransfer.setDragImage(dragIcon,0, 0);
    }
}

ingrese la descripción del enlace aquí

Avatar de usuario de Abhishek Kashyap
Abhishek Kashyap

Puede establecer el atributo arrastrable de img en falso.

  <img id="" src="https://stackoverflow.com/questions/38655964/..." draggable="false">

Y para deshabilitar la selección de imágenes, puede usar

 <style>

img{
    user-drag: none; 
    user-select: none;
    -moz-user-select: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    -ms-user-select: none;
 } 

</style>

¿Ha sido útil esta solución?