Я пытался создать систему перетаскивания для приложения для изучения слов, и столкнулся с проблемой, что перетаскиваемые элементы не могут быть повторно использованы после того, как я верну и попытаюсь перетащить их снова.
Чтобы вернуть перетаскиваемый объект, я использовал метод out, чтобы при его перетаскивании из области сбрасывания он возвращался в прежнее положение. Я сделал это, удалив перетаскиваемый экземпляр и добавив его обратно, если я попытаюсь перетащить этот же элемент обратно в область сбрасывания, которую он не сможет удалить. Я проверил попытки повторной инициализации области сброса, но, похоже, это ничего не меняет.
$(document).ready(function () {
createDraggable();
createDroppable();
});
function createDraggable(){
$(".word").draggable({
containment: ".stage",
revert: 'invalid',
revertDuration: 0
});
}
function disableOtherDraggable(except){
$(".word:not(#" + except.attr('id') + ")").draggable('disable');
}
function createDroppable(){
$('.drop').droppable({
tolerance: 'touch',
accept: '.word',
drop: function(event, ui) {
ui.draggable.position({
my: "center",
at: "center",
of: $(this),
using: function(pos) {
$(this).animate(pos, 200, "linear");
}
});
$(ui.draggable).css('background', "transparent");
disableOtherDraggable(ui.draggable);
},
out: function(event, ui) {
ui.draggable.mouseup(function () {
ui.draggable.removeAttr('style');
$(".word").draggable("destroy");
createDraggable();
});
}
});
}
Я хочу позволить людям отбрасывать слова и перетаскивать их обратно, если это необходимо. Я собираюсь настроить кнопку для проверки правильности пропущенного слова после того, как я получу эту работу.
В этом примере можно перетащить 4 слова, но они могут варьироваться от 3 до 5
Обновление
Вот обновленный код, который я получил, работая для всех, кто заинтересован. Я создал сцену как область, которую можно сбрасывать, и просто включал и выключал ее по мере необходимости.
$(function() {
function createDraggable(o) {
o.draggable({
containment: ".stage",
revert: 'invalid',
revertDuration: 0
});
}
function toggleOtherDraggable() {
$(".words .word").each(function(i, val){
if(!$(val).hasClass('ui-dropped')) $(val).draggable('disable');
});
}
function createLineDroppable(){
$('.drop').droppable({
tolerance: 'touch',
accept: '.word',
drop: function(event, ui) {
ui.draggable.position({
my: "center",
at: "center",
of: $(this),
using: function(pos) {
$(this).animate(pos, 200, "linear");
}
});
$(ui.draggable).css('background', 'transparent');
$(ui.draggable).addClass('ui-dropped');
toggleOtherDraggable();
},
out: function(){
$('#stage-drop').droppable('enable');
}
});
}
function createStageDroppable() {
$('#stage-drop').droppable({
tolerance: 'touch',
accept: '.word',
disabled: true,
drop: function(event, ui) {
$(ui.draggable).css('left', '0');
$(ui.draggable).css('top', '0');
$(ui.draggable).css('background', '');
$(ui.draggable).removeClass('ui-dropped');
$('#stage-drop').droppable('disable');
$(".words .word").draggable('enable');
}
});
}
createDraggable($(".words .word"));
createLineDroppable();
createStageDroppable();
});