使用jQuery拖放交换

时间:2016-02-21 19:58:14

标签: jquery html css jquery-ui drag-and-drop

我想知道如何使用jQuery进行拖放交换。我有3个父div,我有2个子div。我希望子div在没有子div的父div中可以放置,但我不希望任何父div能够存储2个子div。如果将子div拖入带有子div的父div中,我希望交换两个子div。我使用jQuery UI很好,因为下面的代码包含它。

$("document").ready(function() {
  $(".child").draggable({
    revert: true
  });
  $(".parent").droppable({
    accept: '.child',
    drop: function(event, ui) {
      $(this).append($(ui.draggable));
    }
  });
});*
.parent {
   float: left;
   margin-left: 5px;
   height: 200px;
   width: 200px;
   border: 3px solid black
 }
 #child1 {
   height: 50px;
   width: 50px;
   background-color: khaki;
 }
 #child2 {
   height: 50px;
   width: 50px;
   background-color: aqua;
 }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.4/jquery.min.js"</script>
    <script src="https://code.jquery.com/ui/1.11.4/jquery-ui.min.js"></script>      
    <div class="parent">
  <div class="child" id="child1"></div>
</div>
<div class="parent">
  <div class="child" id="child2"></div>
</div>
<div class="parent">
</div>

任何帮助,尤其是代码形式的帮助,都将受到高度赞赏。

jsfiddle:https://jsfiddle.net/g2efds1z/10/

1 个答案:

答案 0 :(得分:1)

嗯,你必须将已经内部的元素移动到另一个中,所以我首先要在你的drop函数中包含这样的代码:

if ($(this).children().length > 0) {
  var move = $(this).children().detach();
  $(ui.draggable).parent().append(move);
}

这添加到整个代码中:

$("document").ready(function() {
  $(".child").draggable({
    revert: true
  });
  $(".parent").droppable({
    accept: '.child',
    drop: function(event, ui) {
    if ($(this).children().length > 0) {
      var move = $(this).children().detach();
      $(ui.draggable).parent().append(move);
    }

      $(this).append($(ui.draggable));
    }
  });
});
.parent {
   float: left;
   margin-left: 5px;
   height: 200px;
   width: 200px;
   border: 3px solid black
 }
 #child1 {
   height: 50px;
   width: 50px;
   background-color: khaki;
 }
 #child2 {
   height: 50px;
   width: 50px;
   background-color: aqua;
 }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js"></script>
<link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/themes/smoothness/jquery-ui.css">
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.11.4/jquery-ui.min.js"></script>      
<div class="parent">
  <div class="child" id="child1"></div>
</div>
<div class="parent">
  <div class="child" id="child2"></div>
</div>
<div class="parent">
</div>