У меня есть один список, который разбит на три столбца следующим образом:
Column1 Column2 Column3
1 4 7
2 5 8
3 6 9
Список непрерывен от 1 до 9, и каждый столбец имеет фиксированное количество строк (3).Я хочу разрешить пользователю изменять порядок списка при сохранении моих столбцов фиксированной длины (3 строки).
Сделать сортировку списка с помощью jQuery было довольно легко.
HTML
<code>< ul class="sortable" id="column1">
< li class="section">1< /li>
< li class="section">2< /li>
< li class="section">3< /li>
< /ul>
< ul class="sortable" id="column2">
< li class="section">4< /li>
< li class="section">5< /li>
< li class="section">6< /li>
< /ul>
< ul class="sortable" id="column3">
< li class="section">7< /li>
< li class="section">8< /li>
< li class="section">9< /li>
< /ul>
Javascript
<code>$('#column1').sortable({
connectWith: ".sortable",
items : ".section"
});
$('#column2').sortable({
connectWith: ".sortable",
items : ".section"
});
$('#column3').sortable({
connectWith: ".sortable",
items : ".section"
});
Это позволяет мне перетаскивать списки, но я не уверен, как сохранить длину столбца.Используя этот метод, каждый список увеличивается и уменьшается по мере перемещения элементов.Любые предложения о хорошем методе для достижения этой цели?
РЕДАКТИРОВАНИЕ С ПОЛНЫМ РЕШЕНИЕМ
Благодаря обоим ответам я получил полное решение.В своем вопросе я не упомянул, что у меня есть заголовок в каждом столбце.
HTML
<code>< ul class="sortable" id="column1">
< li class="header">Header< /li>
< li class="section">1< /li>
< li class="section">2< /li>
< li class="section">3< /li>
< /ul>
< ul class="sortable" id="column2">
< li class="header">Header< /li>
< li class="section">4< /li>
< li class="section">5< /li>
< li class="section">6< /li>
< /ul>
< ul class="sortable" id="column3">
< li class="header">Header< /li>
< li class="section">7< /li>
< li class="section">8< /li>
< li class="section">9< /li>
< /ul>
Javascript
<code>var colLength = 4;
$('#column1, #column2, #column3').sortable({
connectWith: ".draftboard",
items : ".section",
update : balanceColumns
});
balanceColumns: function(event, ui){
function balanceColumn1(){
var col1 = $('#column1 li');
var col2 = $('#column2 li');
var col3 = $('#column3 li');
if (col1.length > colLength){
col1.last().insertAfter( col2[0] );
}
else if(col1.length < colLength){
col2.parent().children(':nth-child(2)').appendTo(col1.parent());
}
}
function balanceColumn2(){
var col1 = $('#column1 li');
var col2 = $('#column2 li');
var col3 = $('#column3 li');
if (col2.length > colLength){<br>
if (col1.length < colLength) {
col2.parent().children(':nth-child(2)').appendTo(col1.parent());
} else {
col2.last().insertAfter( col3[0] );
}
}
else if(col2.length < colLength){
col3.parent().children(':nth-child(2)').appendTo(col2.parent());
}
}
function balanceColumn3(){
var col1 = $('#column1 li');
var col2 = $('#column2 li');
var col3 = $('#column3 li');
if (col3.length > colLength) {
col3.parent().children(':nth-child(2)').appendTo(col2.parent());
balanceColumn2();
}
}
balanceColumn1();
balanceColumn2();
balanceColumn3();
}