我目前有一个列表(ul
和li
)。
使用jQuery进行排序:
$( "#sortable1" ).sortable({
update : function () {
var items = $('#sortable1').sortable('serialize');
alert(items);
}
});
$( "#sortable1" ).disableSelection();
此代码移动完整的li
项(包括它的类 - 因此它是标记)。
有没有办法匹配目标的目的地类?我在这里设置了一个演示:http://tinker.io/65292
所以基本上,当向下移动item 1
一个地方时,item 1
应该变为绿色,item 2
应该变为red
。
此外,当向下移动item 1
两个位置时,item 1
应为黄色,item 2
应为红色,最后item 3
应为绿色。
此演示列表仅存在四个项目,但实际上这可能是任何数字。
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Sortable - Default functionality</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.2/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.2/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<style>
#sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
#sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
#sortable li span { position: absolute; margin-left: -1.3em; }
.first { background-color: red; }
.middle1 { background-color: green; }
.middle2 { background-color: yellow; }
.last { background-color: blue; }
</style>
<script>
$(function() {
$( "#sortable" ).sortable();
$( "#sortable" ).disableSelection();
});
</script>
</head>
<body>
<ul id="sortable">
<li class="first"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
<li class="middle1"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
<li class="middle2"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>
<li class="last"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 4</li>
</ul>
</body>
</html>
答案 0 :(得分:3)
使用nth-child css伪类...
#sortable li:nth-child(1) { background-color: red; }
#sortable li:nth-child(2) { background-color: green; }
#sortable li:nth-child(3) { background-color: yellow; }
#sortable li:nth-child(4) { background-color: blue; }
答案 1 :(得分:2)
根据索引而不是类将css更改为目标列表元素,它将自动更新:
#sortable li:first-child { background-color: red; }
#sortable li:nth-child(2) { background-color: green; }
#sortable li:nth-child(3) { background-color: yellow; }
#sortable li:last-child { background-color: blue; }
答案 2 :(得分:1)
jQuery UI的Sortable基于移动整个DOM元素的原则。
正如您所注意到的那样,移动整个DOM对象,包括其所有内容及其所有属性,以及它的类。
我想到了几种方法:
<li>
上的类。可以使用纯CSS制作第一个红色,第二个绿色等等。您可以通过各种方式使用nth-child
或+
或~
选择器。然后移动<li>
s很好,当它们落入到位时的外观是正确的。