我有两个连接的可排序列表:list_b和list_a.我想要实现的是仅允许可见的占位符list_b.list_a只是用来拉取所以我不想在拖动时占位符list_a(至少是可见空间),但我想list_b在拖动时显示占位符list_a.
基本上:
list_aitem to list_b=显示占位符list_blist_bitem to list_b=显示占位符list_blist_aitem to list_a=不显示占位符,或使用样式为display的占位符:none; 在list_alist_bitem to list_a=不显示占位符,或使用样式为display的占位符:none; 在list_ajQuery的:
$( "#list_a, #list_b" ).sortable({
connectWith: ".connected_sortable",
start: function (e, ui) {
//Closest I can get but now both lists don't show placeholders.
if(ui.item.context.parentNode.id != 'destination_list')
ui.placeholder.hide();
},
}).disableSelection();
Run Code Online (Sandbox Code Playgroud)
HTML:
<ul id="list_a" class="connected_sortable">
<li value="0">test text</li>
<li value="1">test text</li>
</ul>
<ul id="list_b" class="connected_sortable">
<li value="2">test text</li>
</ul>
Run Code Online (Sandbox Code Playgroud)
除了将jQuery draggable插件与可排序插件结合使用之外,有没有办法做到这一点?我不想去那条路,因为我在使用两个插件时遇到了一些jQuery错误.
您可以将list_a连接到list_b但不将list_b连接到list_a.这样将list_b项拖到list_a是不可能的.例:
$( "#list_a" ).sortable({
connectWith: "#list_b"
});
$( "#list_b" ).sortable({
placeholder: "placeholder"
});
$( "#list_a, #list_b" ).disableSelection();
Run Code Online (Sandbox Code Playgroud)
但是,如果你只想隐藏占位符,那么你可以用css做到这一点:
#list_a .placeholder {display:none}
Run Code Online (Sandbox Code Playgroud)