Jquery列表拖放

Jquery list drag drop

本文关键字:拖放 列表 Jquery      更新时间:2023-09-26

我有一个Jquery拖放列表,我想使用Jquery Ajax Post立即在MYSQL中更新它。

因为我可以在列表(多个列表)之间拖动元素,所以我需要获取父 ID(父级是列表类别 ID - 可拖动对象拖动到的位置)

当我从一个类别/列表

拖动到另一个类别/列表时,我总是得到以前的ID。

例如:

1 类 ------------ 2 类

如果我要将某些内容从 CAT1 拖到 CAT2 - ID 将是 CAT1 而不是新的类别 ID......

我在下面添加了我的代码:

Jquery:

<script src="js/jquery.min.js" type="text/javascript"></script>
    <script src="js/jquery.ui.core.js"></script>
    <script src="js/jquery.ui.widget.js"></script>
    <script src="js/jquery.ui.mouse.js"></script>
    <script src="js/jquery.ui.sortable.js"></script>
<script>
    $(function() {
        $( "#sortable1, #sortable2" ).sortable({
            connectWith: ".connectedSortable"
        }).disableSelection();
    });
    </script>

    <script type="text/javascript">
    $(document).ready(function(){
    $(".mouseup").mouseleave(function(){
    var sparent = $(this).parent().attr("id");
    alert(sparent);
    });
    });
    </script>

列表网址:

<div class="demo">
<div class="box">
<ul id="sortable1" class="connectedSortable">
    <li class="ui-state-default mouseup">Item 1</li>
    <li class="ui-state-default mouseup">Item 2</li>
</ul>
</div>
<div class="box">
<ul id="sortable2" class="connectedSortable">
    <li class="ui-state-highlight mouseup">Item 1</li>
    <li class="ui-state-highlight mouseup">Item 2</li>
</ul>
</div>
</div>

任何帮助将不胜感激。

提前谢谢你!

你想要的在这里:http://jqueryui.com/demos/draggable/#events

$( "#sortable1, #sortable2" ).sortable({
    connectWith: ".connectedSortable",
    stop: function(event, ui) { alert($(ui.item).parent().attr("id") }
}).disableSelection();

代码放在停止回调中将允许您检查正确的 ID。

您需要

处理的事件是received

 $(".connectedSortable" ).on( "sortreceive", function(event, ui) { 
     alert(ui.item.parent()[0].id); 
     // also ui.sender will hold original list, from where element was taken
 });

编辑:取决于您是否需要处理项目刚刚重新排序的情况,即您在同一列表中拖放,或者您不打算使用receivedstop事件。 received仅在您拖动到另一个列表时触发。 即使您将项目保留在同一列表中,stop也会触发。