可拖动为可排序为网格

时间:2015-12-14 17:19:53

标签: javascript jquery html css jquery-ui

我正在尝试使用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。

由于

1 个答案:

答案 0 :(得分:1)

发生这种情况的原因是因为子li元素被浮动。

当一个元素浮动时,它基本上是removed from the normal document flow,在这种情况下会导致父元素折叠自身,其高度为0

enter image description here

因此,您无法将元素放入#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;
}