console
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>通过拖放实现添加、删除</title>
<style type="text/css">
div>div{
display:inline-block;
padding:10px;
background-color:#aaa;
margin:3px;
}
</style>
</head>
<body>
<div style="width:600px;border:1px solid black;">
<h2>可将你喜欢的项目拖进收藏夹</h2>
<div draggable="true" ondragstart="dsHandler(event);">项目1</div>
<div draggable="true" ondragstart="dsHandler(event);">项目2</div>
<div draggable="true" ondragstart="dsHandler(event);">项目3</div>
<div draggable="true" ondragstart="dsHandler(event);">项目4</div>
<div draggable="true" ondragstart="dsHandler(event);">项目5</div>
</div>
<div id="dest" style="width:400px;height:400px;border:1px solid black;float:left;">
<h2 ondragleave="return false">收藏夹</h2>
</div>
<div id="gb" draggable="false" style="float:left;width:100px;height:100px;border:1px solid black;">垃圾桶</div>
<script type="text/javascript">
var dest = document.getElementById("dest");
var dsHandler = function(evt){
evt.dataTransfer.setData("text/plain","<item>" + evt.target.innerHTML);
}
dest.ondrop = function(evt){
var text = evt.dataTransfer.getData("text/plain");
if(text.indexOf("<item>") == 0){
var newEle = document.createElement("div");
newEle.id = new Date().getUTCMilliseconds();
newEle.innerHTML = text.substring(6);
newEle.draggable = "true";
newEle.ondragstart = function(evt){
evt.dataTransfer.setData("text/plain","<remove>"+newEle.id);
}
dest.appendChild(newEle);
}
}
document.getElementById("gb").ondrop = function(evt)
{
var id = evt.dataTransfer.getData("text/plain");
if (id.indexOf("<remove>") == 0)
{
var target = document.getElementById(id.substring(8));
dest.removeChild(target);
}
}
document.ondragover = function(evt)
{
return false;
}
document.ondragleave = function(evt){
return false;
}
document.ondrop = function(evt)
{
return false;
}
</script>
</body>
</html>