Перетащите мышью с помощью базового фреймворка

Можно ли добиться перетаскивания с помощью базового сценария jQuery (без использования пользовательского интерфейса jQuery)?

1 ответ

Решение

В 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);

Надеюсь, что это помогает на данный момент.

Другие вопросы по тегам