Jquery UI 可排序 - 可拖动 - 丢失可排序

发布于 2024-12-21 15:17:56 字数 2830 浏览 3 评论 0原文

我有一个 jquery ui 可排序列表。我设置了一个“垃圾桶”来扔掉列表中不想要的项目。一旦我在列表项上设置了“可拖动”,它们就不再排序。

垃圾桶 使

$("#trash").droppable({
      drop: function(ev, li)
      {
        var $element = li.draggable;
        $element.remove();
    $.ajax({                                      
        url: 'deltask.php',                          
        data: 'id='+$element.attr('id'),            
        dataType: 'html',                   
        success: function(data)          
        {
        }
    });

      }
});

列表可排序

    // set our listdiv ul as sortable 
    $("#listdiv ul").sortable({ opacity: 0.6, cursor: 'move', update: function(){
        var order = $(this).sortable("serialize") + '&action=update'; 
        $.post("updatelist.php", order, function(){
        });                                                              
    }                                 
    }); // listdiv ul end

并使该 ul 中的所有列表项可拖动,以便我可以拖动和丢弃:

    $("#listdiv li").draggable({
        opacity : 0.7,
        revert  : 'invalid',
                helper  : 'clone',
                zIndex  : 100,
                cursor  : 'move'
        });

只要我不包含上面使

  • 的部分,排序就可以工作是可拖动的。添加该功能后,我可以拖动它们并将其丢弃,但列表项不再可排序。
  • 请问我有什么不好吗?

    谢谢, 史蒂夫

    注意:我不知道回答自己问题的协议,所以我只是编辑我原来的问题!如果我这样做错了,请有人打我。

    解决上述问题的方法:

    睡了一觉后,我想“为什么还要费心制作我的可排序列表

  • < /code> 可拖动并使我的垃圾桶可投放?”
  • 我只是让我的垃圾桶可排序,并在我的列表 div 和垃圾 div 上使用 connectwith 并设置一个接收事件处理程序,这应该可以工作吗?让我们看看...

    $("#trash").sortable({
    
          connectWith: '#listdiv',
          receive: function(event, ui)
          {
         var $element = ui.item;
    //        alert ( $element.attr('id') ) ;
    
            // remove this from original list
            $element.remove();
    
        //remove this item from trash list
        $("#trash li").remove(),
    
            // remove from database
        $.ajax({                                      
                url: 'deltask.php',                          
                data: 'id='+$element.attr('id'),            
                dataType: 'html',                   
                success: function(data)          
                {
                //  alert(data);
                }
        });
    
          } // end receive
    }); // end trash
    
    
    
    // set our listdiv ul as sortable 
    $("#listdiv ul").sortable({
        opacity: 0.6,
        cursor: 'move',
        connectWith: '#trash',
        update: function()
            {
                var order = $(this).sortable("serialize") + '&action=update'; 
                $.post("updatelist.php", order, function(){
                });      
            }   
    }); // end  listdiv ul sortable
    

    我的原始列表排序良好,我可以将列表项拖到垃圾“列表”中,然后在它从原始列表、垃圾列表和我的数据库到达时将其删除()。

    也许不太优雅,但是嘿,它有效。

    I have a jquery ui sortable list. I set up a "trash can" to get rid of items I didn't want on a list. Once I had the 'draggable' set up on my list items, they no longer sort.

    trash can

    $("#trash").droppable({
          drop: function(ev, li)
          {
            var $element = li.draggable;
            $element.remove();
        $.ajax({                                      
            url: 'deltask.php',                          
            data: 'id='+$element.attr('id'),            
            dataType: 'html',                   
            success: function(data)          
            {
            }
        });
    
          }
    });
    

    Making the list sortable

        // set our listdiv ul as sortable 
        $("#listdiv ul").sortable({ opacity: 0.6, cursor: 'move', update: function(){
            var order = $(this).sortable("serialize") + '&action=update'; 
            $.post("updatelist.php", order, function(){
            });                                                              
        }                                 
        }); // listdiv ul end
    

    and making all list items in that ul draggable so I can drag and trash:

        $("#listdiv li").draggable({
            opacity : 0.7,
            revert  : 'invalid',
                    helper  : 'clone',
                    zIndex  : 100,
                    cursor  : 'move'
            });
    

    Sorting works as long as I don't include the section just above that makes the <li>'s draggable. Adding that let's me drag and trash em but the list items are no longer sortable.

    What's my bad, please?

    Thanks,
    Steve

    NOTE: I don't know the protocol for answering ones own question so I'm just editing my original question! Someone slap me if I'm wrong to do this pls.

    Workaround to the problem stated above:

    After sleeping on it I thought "Why bother with making my sortable list <li>'s draggable and make my trash can a droppable?"

    I just make my trash can a sortable and use connectwith on my list div and trash div and set up a receive event handler and that should work? Let's see...

    $("#trash").sortable({
    
          connectWith: '#listdiv',
          receive: function(event, ui)
          {
         var $element = ui.item;
    //        alert ( $element.attr('id') ) ;
    
            // remove this from original list
            $element.remove();
    
        //remove this item from trash list
        $("#trash li").remove(),
    
            // remove from database
        $.ajax({                                      
                url: 'deltask.php',                          
                data: 'id='+$element.attr('id'),            
                dataType: 'html',                   
                success: function(data)          
                {
                //  alert(data);
                }
        });
    
          } // end receive
    }); // end trash
    
    
    
    // set our listdiv ul as sortable 
    $("#listdiv ul").sortable({
        opacity: 0.6,
        cursor: 'move',
        connectWith: '#trash',
        update: function()
            {
                var order = $(this).sortable("serialize") + '&action=update'; 
                $.post("updatelist.php", order, function(){
                });      
            }   
    }); // end  listdiv ul sortable
    

    My original list sorts fine and I can drag a list item to the trash "list" and just remove() it when it arrives from the original list, the trash list, and from my database.

    Perhaps not too elegant but hey, it works.

    如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

    扫码二维码加入Web技术交流群

    发布评论

    需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
    列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文