Предотвращение возврата клонов при замене элементов с помощью пользовательского интерфейса jQuery - PullRequest
0 голосов
/ 17 декабря 2011

Я использую jQuery draggable / droppable, чтобы включить элементы в сетке для обмена.Например, когда элемент 1 сбрасывается на элемент 2, они меняются местами.

Есть две проблемы:

  1. После успешного перетаскивания клон все еще возвращается вего исходное положение.Как я могу предотвратить это?Я только хочу, чтобы он всплыл обратно, если он не сброшен на действительную цель.

  2. В идеале я хотел бы также установить helper: original, но когда я попробовал это, я не смогВыясните, как правильно рассчитать измененные позиции в функции drop.

Я поместил код в jsFiddle и ниже для справки:

<div id="room"></div>

<script>
$(function() {
//Set up seats - four rows of eight
for (var row = 0; row < 4; row++) {
    for (var col = 0; col < 8; col++) {
        $('#room').append('<div class="seat" style="top: ' + (row * 45 + 15) + 'px; left: ' + (col * 117 + 18) + 'px;">' + (row * 4 + col + 1) + '</div>');
    }
}

//Swap function from http://blog.pengoworks.com/index.cfm/2008/9/24/A-quick-and-dirty-swap-method-for-jQuery
jQuery.fn.swap = function(b) {
    b = jQuery(b)[0];
    var a = this[0];
    var t = a.parentNode.insertBefore(document.createTextNode(''), a);
    b.parentNode.insertBefore(a, b);
    t.parentNode.insertBefore(b, t);
    t.parentNode.removeChild(t);
    return this;
};

$(".seat").draggable({
    revert: true,
    helper: "clone"
});

$(".seat").droppable({
    accept: ".seat",
    hoverClass: "ui-state-hover",
    drop: function(event, ui) {

        var draggable = ui.draggable,
            droppable = $(this),
            dragPos = draggable.position(),
            dropPos = droppable.position();

        draggable.css({
            left: dropPos.left + 'px',
            top: dropPos.top + 'px'
        });

        droppable.css({
            left: dragPos.left + 'px',
            top: dragPos.top + 'px'
        });
        draggable.swap(droppable);
    }
});

});
</script>

1 Ответ

0 голосов
/ 18 декабря 2011

Я решил это с помощью $(ui.helper).hide(); в функции drop.

...