我正在尝试将 jquery-ui 可排序列表放入手风琴部分并连接这些列表。这个想法是创建一个紧凑而直观的界面,用于对几个不同类别的项目进行排序。项目通常在一个部分内分类,但有时它们可能会被带到另一个手风琴部分。
我快到了:http: //jsfiddle.net/arasbm/H5MRw/7/
以下是 HTML 代码示例:
<div id="accordion">
<h3 class="accordion-header"><a href="#">good</a></h3>
<div class="accordion-section">
<ul class="sortable-list">
<li>dog</li>
<li>butter</li>
</ul>
</div>
...
</div>
和javascript:
// Setup the accordion
$("#accordion").accordion();
var $accordion = $("#accordion").accordion();
//Setup the sortable list
$("ul.sortable-list").sortable({
connectWith: "ul.sortable-list", // connect all sortable lists together so items can be dragged from one list to aother
stop: function(event, ui) {
console.log("an item was moved");
}
}).disableSelection();
$("h3.accordion-header").droppable({
over: function(event, ui) {
//it would be ideal to have some sort of tollorance or delay so user does not accidentally expand another section or accordion
$(this).css('color', 'red');
$accordion.accordion('activate', $(this));
},
out: function(event, ui) {
$(this).css('color', 'green');
}
});
尚未工作的部分是在将项目从一个列表拖到另一个列表时向用户显示正确的视觉反馈。当用户在另一个手风琴部分的标题顶部拖动一个项目时,该部分被激活,但是,由于某种原因,在拖动过程中使用的元素不知何故消失了。该项目实际上仍然存在,如果您继续将其放入列表中,您可以看到占位符出现,您可以将项目放入新位置。
如何修复此实现,以便用户即使在转到手风琴的另一部分时也可以看到他们正在拖动的项目。我将不胜感激解决此问题的任何帮助,但请使用我提供的 jsFiddle来演示您的解决方案。