7

是否可以使用基本的 jQuery 脚本(不使用 jQuery UI)实现拖放?

4

1 回答 1

16

在 HTML5 中,有一个名为“可拖动”的属性。

<div draggable='true'>Drag me</div>
<div id='dropzone'>Drop it here!</div>

您可以利用以下事件:

var onDragEnter = function(event) {
    event.preventDefault();
    $("#dropzone").addClass("dragover");
}, 

onDragOver = function(event) {
    event.preventDefault(); 
    if(!$("#dropzone").hasClass("dragover"))
        $("#dropzone").addClass("dragover");
}, 

onDragLeave = function(event) {
    event.preventDefault();
    $("#dropzone").removeClass("dragover");
},

onDrop = function(event) {
    event.preventDefault();
    $("#dropzone").removeClass("dragover");
    console.log(event.originalEvent.dataTransfer.files);
};

$("#dropzone")
.on("dragenter", onDragEnter)
.on("dragover", onDragOver)
.on("dragleave", onDragLeave)
.on("drop", onDrop);

希望暂时能有所帮助。

于 2012-03-06T10:39:05.257 回答