接受的解决方案更清洁,但有 1 个问题。一旦将可拖动对象拖放到绿色区域上,即使在白色区域上也将变为可拖放对象...(注意revert: false
)使用正确代码更新该答案。
演示2
$('.draggable').draggable({
revert: 'invalid'
});
$('#droppable, #block').droppable({
accept: '.draggable',
drop: function( event, ui ) {
if(!ui.draggable.data('original')){
ui.draggable.data('original',ui.draggable.draggable("option", "revert"));
}
if (this.id == 'block') {
ui.draggable.draggable({ revert: true });
} else {
ui.draggable.draggable({ revert: ui.draggable.data('original') });
}
}
});
看起来这个问题已经有了答案。但这是我解决同样问题的尝试。
演示
$('#block').droppable({
accept: '.draggable',
drop: function (event, ui) {
if (ui.draggable.data('revert')) {
ui.draggable.data('revert', false);
var old = ui.draggable.draggable("option", "revert");
ui.draggable.draggable("option", "revert", true);
setTimeout(function () {
ui.draggable.draggable("option", "revert", old);
}, 100);
}
},
out: function (event) {
$('.draggable').data('revert', false);
},
over: function (event,ui) {
ui.draggable.data('revert', true);
}
});
$('#droppable').droppable({
accept: function (elem) {
if ($('.draggable').data('revert')) {
return false;
}
return elem.hasClass("draggable");
}
});
$('.draggable').draggable({
revert: 'invalid'
});