我正在尝试使用jquery创建可拖动列表到可排序列表中。
一切正常,除非使用CSS将此列表转换为网格。一旦所有内容都显示为网格,可拖动到可排序的停止工作。
我的 HTML 是:
<ul id="sortable2">
<li class="ui-state-highlight">A</li>
<li class="ui-state-highlight">B</li>
<li class="ui-state-highlight">C</li>
<li class="ui-state-highlight">D</li>
</ul>
<ul id="sortable">
<li class="ui-state-default">1</li>
<li class="ui-state-default">2</li>
<li class="ui-state-default">3</li>
</ul>
我的页面 SCRIPT 是:
$(function() {
$("#sortable").sortable();
$("#sortable2 li").draggable({
connectToSortable: "#sortable",
helper: "clone"
});
});
我添加了 CSS 以使UL显示为网格:
#sortable {
list-style-type: none;
margin: 0;
padding: 0;
width: 450px;
}
#sortable li {
margin: 3px 3px 3px 0;
padding: 1px;
float: left;
width: 100px;
height: 90px;
font-size: 4em;
text-align: center;
}
#sortable2 {
list-style-type: none;
margin: 0;
padding: 0;
width: 450px;
}
#sortable2 li {
margin: 3px 3px 3px 0;
padding: 1px;
float: left;
width: 100px;
height: 90px;
font-size: 4em;
text-align: center;
}
有什么想法吗?
我正在使用jquery-ui.css,jquery-ui.js和jquery.min.js。
由于
答案 0 :(得分:1)
发生这种情况的原因是因为子li
元素被浮动。
当一个元素浮动时,它基本上是removed from the normal document flow,在这种情况下会导致父元素折叠自身,其高度为0
:
因此,您无法将元素放入#sortable
元素,因为它没有高度。
最常见的解决方法是使用a clearfix来防止父元素崩溃。
将overflow: auto
添加到容器元素(example):
ul {
overflow: auto;
}
或使用伪元素(example):
ul:after {
content: '';
clear: both;
display: table;
}
或者,您也可以从float: left
元素中删除li
,然后将display
设置为inline-block
。此外,在添加元素(example)时,应添加vertical-align: top
以解决次要对齐问题:
ul li {
display: inline-block;
vertical-align: top;
}