jquery draggable & droppable get source container (that draggable came from)

后端 未结 1 448
渐次进展
渐次进展 2021-01-19 09:55

I made this jsfiddle for a different answer and I\'m wondering how I can get the souce container that the droppable came from

http://jsfiddle.net/d7wsz/8/

Th

相关标签:
1条回答
  • 2021-01-19 10:44

    You can use a variable which you set in the start event of the draggable and get that info in the stop event of the droppable.

    $(function () {
        var sourceElement;
        $("#Table1 tr:not(.disabled), #Table2 tr:not(.disabled), #Table3 tr:not(.disabled)").draggable({
            helper: 'clone',
            revert: 'invalid',
            start: function (event, ui) {
                $(this).css('opacity', '.5');
                //NEW
                sourceElement = $(this).closest('table').attr('id');
            },
            stop: function (event, ui) {
                $(this).css('opacity', '1');
            }
        });
    
        $("#Table1, #Table2, #Table3").droppable({
            drop: function (event, ui) {
                $(ui.draggable).appendTo(this);
                //alert sourceElement
                alert($(ui.draggable).text() +
                    ' was draged from ' + sourceElement + ' to ' + $(this).attr('id') + '.');
    
            }
        });
    
    });
    

    See my updated jsfiddle If you have more than those tables on your page you might think about giving them a class to properly identify them.

    0 讨论(0)
提交回复
热议问题