复制代码代码如下: !DOCTYPE HTML html head title Example /title style #src * { float: left; } #target, #src img { border: thin solid black; padding: 2px; margin: 4px; } #target { height: 123px; width: 220px; text-align: center; display: table; } #target p { display: table-cell; vertical-align: middle; } #target img { margin: 1px; } img.dragged { background-color: lightgrey; } /style /head body div id="src" img draggable="true" id="car1" src="img/1.jpg" alt="car1" / img draggable="true" id="car2" src="img/2.jpg" alt="car2" / img draggable="true" id="car3" src="img/3.jpg" alt="car3" / div id="target" p id="msg" drop here /p /div /div script var src = document.getElementById("src"); var target = document.getElementById("target"); var msg = document.getElementById("msg"); var draggedID; target.ondragenter = handleDrag; target.ondragover = handleDrag; function handleDrag(e) { e.preventDefault(); } target.ondrop = function (e) { var newElem = document.getElementById(draggedID).cloneNode(false); target.innerHTML = ""; target.appendChild(newElem); e.preventDefault(); } src.ondragstart = function (e) { draggedID = e.target.id; e.target.classList.add("dragged"); } src.ondragend = function (e) { var elems = document.querySelectorAll(".dragged"); for (var i = 0; i elems.length; i++) { elems[i].classList.remove("dragged"); } } /script /body /html
运行结果:
4.使用DataTransfer 我们使用DataTransfer从拖拽对象向投放区传递数据。DataTransfer有下面的属性和方法:types:返回数据的格式;getData( format ):返回指定格式数据;setData( format , data ):设置指定格式数据;clearData( format ):移除指定格式数据;files:返回已经投放的文件数组。 我们来看下面的例子,他实现的效果和例3一样:
复制代码代码如下: !DOCTYPE HTML html head title Example /title style #src * { float: left; } #src img { border: thin solid black; padding: 2px; margin: 4px; } #target { border: thin solid black; margin: 4px; } #target { height: 123px; width: 220px; text-align: center; display: table; } #target p { display: table-cell; vertical-align: middle; } img.dragged { background-color: Orange; } /style /head body div id="src" img draggable="true" id="car1" src="img/1.jpg" alt="car1" / img draggable="true" id="car2" src="img/2.jpg" alt="car2" / img draggable="true" id="car3" src="img/3.jpg" alt="car3" / div id="target" p id="msg" drop here /p /div /div script var src = document.getElementById("src"); var target = document.getElementById("target"); target.ondragenter = handleDrag; target.ondragover = handleDrag; function handleDrag(e) { e.preventDefault(); } target.ondrop = function (e) { var droppedID = e.dataTransfer.getData("Text"); var newElem = document.getElementById(droppedID).cloneNode(false); target.innerHTML = ""; target.appendChild(newElem); e.preventDefault(); } src.ondragstart = function (e) { e.dataTransfer.setData("Text", e.target.id); e.target.classList.add("dragged"); } src.ondragend = function (e) { var elems = document.querySelectorAll(".dragged"); for (var i = 0; i elems.length; i++) { elems[i].classList.remove("dragged"); } } /script /body /html
复制代码代码如下: !DOCTYPE HTML html head title Example /title style .table { display: table; } .row { display: table-row; } .cell { display: table-cell; padding: 5px; } .label { text-align: right; } #target { border: medium double black; margin: 4px; height: 50px; width: 200px; text-align: center; display: table; } #target p { display: table-cell; vertical-align: middle; } /style /head body form id="fruitform" method="post" action="/UploadHandler.ashx" div div div Bananas: /div div input name="bananas" value="2" / /div /div div div Apples: /div div input name="apples" value="5" / /div /div div div Cherries: /div div input name="cherries" value="20" / /div /div div div File: /div div input type="file" name="file" / /div /div div div Total: /div div id="results" items /div /div /div div id="target" p id="msg" Drop Files Here /p /div button id="submit" type="submit" Submit Form /button /form script type="text/javascript" var target = document.getElementById("target"); var httpRequest; var fileList; target.ondragenter = handleDrag; target.ondragover = handleDrag; function handleDrag(e) { e.preventDefault(); } target.ondrop = function (e) { fileList = e.dataTransfer.files; e.preventDefault(); } document.getElementById("submit").onclick = function handleButtonPress(e) { e.preventDefault(); var form = document.getElementById("fruitform"); var formData = new FormData(form); if (fileList) { for (var i = 0; i fileList.length; i++) { formData.append("file" + i, fileList[i]); } } httpRequest = new XMLHttpRequest(); httpRequest.onreadystatechange = handleResponse; httpRequest.open("POST", form.action); httpRequest.send(formData); } function handleResponse() { if (httpRequest.readyState == 4 httpRequest.status == 200) { var data = JSON.parse(httpRequest.responseText); document.getElementById("results").innerHTML = "You ordered " + data.total + " items"; } } /script /body /html