我想知道如何使用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/
答案 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>