Sto tentando di riordinare gli elementi DOM SVG utilizzando gli eventi di trascinamento e rilascio nativi. Il codice seguente sembra funzionare (con alcuni strani effetti di immagine) in Firefox, funziona un numero limitato di volte in Chrome (funzionano 2 o 3 riordinamenti di trascinamento/rilascio, quindi sembra bloccarsi) e non molto bene in IE. La mia ipotesi migliore è che ci sia qualcosa sugli eventi in questione a cui non sto pensando correttamente, qualche tipo di reset. O forse usando gli eventi di trascinamento senza dataTransfer in questo modo non è corretto. Il mio obiettivo è comprendere questo tipo di funzione senza librerie, ma per avere una comprensione più chiara delle funzioni DOM, javascript, HTML e CSS al livello più elementare. Potrei facilmente sbagliare da qualche parte in quella lista.HTML5 trascinare la manipolazione DOM con javascript
<!DOCTYPE html>
<html>
<head>
<title>Drag and Drop Experiments</title>
<style>svg { border-width:3px} </style>
</head>
<body>
<div id="main">
<svg id="s1" draggable="yes" width="100" height="100">
<circle cx="50" cy="50" r="30" fill="blue"></circle>
</svg>
<svg id="s2" draggable="yes" width="100" height="100">
<circle cx="50" cy="50" r="30" fill="red"></circle>
</svg>
<svg id="s3" draggable="yes" width="100" height="100">
<circle cx="50" cy="50" r="30" fill="yellow"></circle>
</svg>
</div>
<script type="text/javascript">
var dragSourceElement = null;
var dragTargetElement = null;
function doDragStart(e){
this.style.opacity = "0.4";
this.style.border = "solid";
dragSourceElement = this;
}
function doDragEnter(e){
if(dragSourceElement != this){
this.style.border = "dashed";
}
}
function doDragLeave(e){
if(dragSourceElement != this){
this.style.border = "";
}
}
function doDragOver(e){
if(dragSourceElement != this){
dragTargetElement = this;
e.preventDefault();//to allow a drop?
}
}
function doDragEnd(e){
this.style.border = "";
this.style.opacity = "1.0";
}
function doDragDrop(e){
if(dragSourceElement != dragTargetElement){
dnd_svg(dragSourceElement,dragTargetElement);
}
dragSourceElement.style.border = "";
dragTargetElement.style.border = "";
dragSourceElement.style.opacity = "";
dragSourceElement = null;
dragTargetElement = null;
}
//called after a drag and drop
//to insert svg element c1 before c2 in the DOM
//subtree of the parent of c2, assuming c1 is
//dropped onto c2
function dnd_svg(c1,c2){
var parent_c2 = c2.parentElement;
parent_c2.insertBefore(c1,c2);
}
function addL(n){
n.addEventListener('dragstart',doDragStart,false);
n.addEventListener('dragenter',doDragEnter,false);
n.addEventListener('dragleave',doDragLeave,false);
n.addEventListener('dragover',doDragOver,false);
n.addEventListener('drop',doDragDrop,false);
}
addL(document.getElementById("s1"));
addL(document.getElementById("s2"));
addL(document.getElementById("s3"));
</script>
</body>
</html>
Nota: c'è un errore javascript nella funzione dnd_svg in IE9. var parent_c2 = c2.parentElement? c2.parentElement: c2.parentNode; lo risolve per me. Vedi http://jsfiddle.net/nrNSS/. – stevebot