我试图让以下代码工作,其中应该克隆selectable中的元素并将其附加到不同选项卡中的sortable。但是,可选择的节点根本没有克隆,而是被删除并附加到sortable。这是代码:
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2 /jquery.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.14/jquery-ui.min.js"></script>
<link rel="stylesheet" type="text/css" href="ui-lightness/jquery-ui-1.8.15.custom.css">
<script type="text/javascript">
$(function() {
var $tabs = $('#tabs').tabs();
$( "#selectable" ).selectable();
$('li', '#selectable').draggable({
connectToSortable: '#sortable',
helper: 'clone',
revert: 'invalid'
});
var $tab_items = $('ul:first li', $tabs).droppable({
accept : '#selectable li',
hoverClass : 'ui-state-hover',
drop : function(event, ui) {
var $item = $(this);
var $list = $($item.find('a').attr('href')).find('.connectedSortable');
$tabs.tabs('select', $tab_items.index($item));
$(this).appendTo($list).show('slow');
}
});
$('#selectable, #sortable').disableSelection();
});
</script>
</head>
<body>
<div id="tabs">
<ul>
<li><a href="#tab-selectable">Tab1</a></li>
<li><a href="#tab-sortable">Tab2</a></li>
</ul>
<div id="tab-selectable">
<ul id="selectable">
<li id="e101" class="ui-state-default">Num 1</li>
<li id="e102" class="ui-state-default">Num 2</li>
<li id="e103" class="ui-state-default">Num 3</li>
<li id="e104" class="ui-state-default">Num 4</li>
<li id="e105" class="ui-state-default">Num 5</li>
</ul>
</div>
<div id="tab-sortable">
<ul id="sortable" class="connectedSortable ui-helper-reset">
</ul>
</div>
</div>
</div>
</body>
有什么想法吗?
答案 0 :(得分:0)
使用简单的ui.draggable.clone()
,它终于奏效了。