场景:拖动一个或多个元素并将它们放到另一个列表中,但不要从源列表中删除拖动的元素。
为了允许多次拖动,我使用了Aaron Blenkush 在这里发布的代码。
我进行了更改以满足我的需求,例如修复 Shift 问题。
  $("ul").on('click', 'li', function (e) {
      if (e.ctrlKey || e.metaKey) { //meta key for mac users
          $(this).toggleClass("ui-selected");
          $(this).parent().parent().siblings().children('ul').children().removeClass('ui-selected');
    }
    else if (e.shiftKey) {
        // $(this).toggleClass("selected");               
        var list = $(this).parent();
        var first = list.find('.ui-selected').first().index();
        // var last = list.find('.selected').last().index();
        var last = $(this).index();
        if (first == -1 || last == -1) {
            return false;
        }
        if (last < first) {
            firstHolder = first;
            first = last;
            last = firstHolder;
        }
        for (i = first; i <= last ; i++) {
            list.children().eq(i).addClass("ui-selected");
        }
    }
    else {                
        $(this).addClass("ui-selected").siblings().removeClass('ui-selected'); //select only clicked element and unselecting other elements
        //to Remove selected Class from 2nd UL li
        $(this).parent().parent().siblings().children('ul').children().removeClass('ui-selected');
    }
})
   .sortable({
       connectWith: "ul",
       delay: 150, //Needed to prevent accidental drag when trying to select
       revert: 0,
       cursor: "move",
       disabled: false,
       placeholder: 'placeholder',
       //  handle: ".handle",
       helper: function (e, item) {
           //Basically, if you grab an unhighlighted item to drag, it will deselect (unhighlight) everything else
           if (!item.hasClass('ui-selected')) {
               item.addClass('ui-selected').siblings().removeClass('ui-selected');
           }
           //////////////////////////////////////////////////////////////////////
           //HERE'S HOW TO PASS THE SELECTED ITEMS TO THE `stop()` FUNCTION:
           //Clone the selected items into an array
           var elements = item.parent().children('.ui-selected').clone();
           //Add a property to `item` called 'multidrag` that contains the selected items, then remove the selected items from the source list
           item.data('multidrag', elements)
               //.siblings('.ui-selected').remove();
           //Now the selected items exist in memory, attached to the `item`, so we can access them later when we get to the `stop()` callback
           //Create the helper
           var helper = $('<li/>');
           return helper.append(elements);
       },
       start: function(event, ui) {
           //$(ui.item).show();
           var elements = ui.item.data('multidrag');
           ui.item.after(elements);
           //clone = $(ui.item).clone();
           //before = $(ui.item).prev();
       },
       stop: function (e, ui) {
           //Now we access those items that we stored in `item`s data!
           var elements = ui.item.data('multidrag');
           //`elements` now contains the originally selected items from the source list (the dragged items)!!
           //Finally I insert the selected items after the `item`, then remove the `item`, since item is a duplicate of one of the selected items.
           ui.item.after(elements).remove();
         //  $(ui.item).show();
           //$(this).sortable('cancel');
       }
   });
问题:它从源列表中删除删除的元素。
我对这个问题进行了一些研究。有人说在辅助方法中使用克隆,但是当我传递给返回多个元素的函数时,我不能使用克隆。在 Firebug 中,当我拖动元素时,它会将style=display:none放在它们上面,但是当我放置元素时,它会将它们从源列表中删除。
更新
我对接受的答案进行了一些更改,以使其更简单
有一些问题,比如当 li 从第一个列表掉到第二个列表时。并且您将 li 从第 2 拖回第 1 它将删除元素
解决方案是当项目被放入第二个列表时删除ui-selected类。
我希望它会帮助一些人:)