我是JQuery的新手,基本上是整个网络开发。我试图将一些div(+他们的内容)从左div(#selection)拖到右div(#drop),然后在'#drop'div中将它们排序。我已经完成了拖动部分,但是,即使我已经实现了必要的代码,它们也无法在'#drop'div中排序。
源代码:
html结构:
<body class="doc">
<div id="header">Business Entry</div>
<div id="content">
<div id="selection">
<div id="dragTelNr" class="draggableElement">
Telephone Number
</div>
<div id="address" class="draggableElement">
Address
</div>
</div>
<div id="drop">
</div>
<div class="clear"></div>
</div>
</body>
JS:
$(document).ready(function () {
$.fn.exists = function () {
return this.length !== 0;
}
var ids = new Array();
ids[0] = 1;
ids[1] = 1;
var nextSibling;
var draggableOptions = { opacity: 0.6, revert: true, containment: '#content', zIndex: 100};
$('.draggableElement').draggable({opacity: 0.6, revert: true, containment: '#content', zIndex: 100,
start: function(event, ui){
//nextSibling = ui.helper.next();
}
});
$('#drop').droppable({
hoverClass: '.dropHover',
accept: '.draggableElement',
activate: function(event, ui){
nextSibling = ui.draggable.next();
},
drop: function(event, ui){
var draggable = ui.draggable;
if (draggable.parent().attr('id') != 'drop'){
var draggableId = draggable.attr('id');
if (nextSibling.exists() == false){
$( '<div id = "' + draggableId + '" class="draggableElement"></div>' ).html( ui.draggable.html()).draggable(draggableOptions).appendTo('#selection');
alert("Insert at the end " + nextSibling);
}
else{
$( '<div id = "' + draggableId + '" class="draggableElement"></div>' ).html( ui.draggable.html()).draggable(draggableOptions).insertBefore(nextSibling);
alert("Insert before " + nextSibling);
}
switch(draggableId){
case 'dragTelNr':
alert(draggable.attr('id'));
draggable.attr('id', draggableId + ids[0]).appendTo($(this));
alert(draggable.attr('id'));
ids[0]++;
break;
case 'address':
alert(draggable.attr('id'));
draggable.attr('id', draggableId + ids[1]).appendTo($(this));
alert(draggable.attr('id'));
ids[1]++;
break;
}
}
}
});
$('#drop').sortable();
//$('#drop').dissableSelection();
});
的CSS:
.doc {
margin:auto; /* center in viewport */
width: 1000px; /* fix page width */
}
#header {
height: 80px;
width: 990px;
background:#efefef;
border: 1px solic black;
text-align: center;
font: bold 180% arial;
padding: 1em;
}
#selection {
width: 300px;
height: 500px;
border: 1px solid black;
float: left;
background-color: #D3D3D3;
text-align:center;
}
#drop {
width: 670px;
height: 500px;
border: 1px solid black;
float: left;
text-align: center;
}
.clear {
clear: both;
}
#content {
width: 990px;
height: 500px;
}
.draggableElement {
line-height: 1.286;
margin-top: 1.286em;
margin-bottom: 1.286em;
border: 2px solid black;
}
.dropHover{
border: 3px solid black;
}
顺便说一下,库已被正确导入,所以问题就不存在了。如果有人提出如何使其发挥作用的建议,我将非常感激。
以下是我的源代码的链接:http://jsfiddle.net/Bt23y/
答案 0 :(得分:3)
我清理你的小提琴,专注于重要的事情:
如果您希望能够将项目从一个列表拖到另一个列表使其可排序,则可以使用jqueryUI的connectWith
sortable
<ul id="selection">
<li>Item1</li>
<li>Item2</li>
</ul>
<ul id="drop"></ul>
$('#drop').sortable({connectWith: $('#selection')});
$('#selection').sortable({connectWith: $('#drop')});
答案 1 :(得分:1)
“通过将选择器传递给connectWith选项,将项目从一个列表排序到另一个列表,反之亦然。最简单的方法是使用CSS类对所有相关列表进行分组,然后将该类传递给可排序函数(即connectWith:'。myclass')。“
$('.sortableContainer).sortable({
...
connectWith: ".sortableContainer",
...
})