我试图根据输入数据属性中的项目顺序,使用jQuery对html元素进行排序。 "数据顺序"
请参阅此处的代码设置,但我被卡住了。
http://jsbin.com/cixolonoqe/1/edit?html,js,output
HTML:
<div id="control">
<input type="hidden" data-order="title,text,date">
</div>
<div id="parts">
<p class="date part">20 January 2014</p>
<h5 class="title part">Some Title</h5>
<p class="text part">A line of Text</p>
</div>
jQuery的:
var input = $('#control input');
var partsOrder = input.attr("data-order");
var parts = $('#parts');
parts.find('.part').each(function(i) {
$(this).attr('data-index', 'index' + i);
});
//Make array from data-order attribute
var partsArray = partsOrder.split(',');
$.partsArray(json, function(i, val) {
//modify html order
});
如果数据顺序字符串发生变化,我希望html重新排序。
标题,文字,日期与日期,文字,标题
到目前为止,我已将原始索引的新数据属性添加到零件上。并从数据顺序字符串创建一个数组,以便循环并修改html。
但我无法理解它。
答案 0 :(得分:1)
您可以将目标索引放在元素上,将它们放入数组中,对索引上的数组进行排序,然后根据数组重新排列元素:
var partsOrder = $('#control input').attr("data-order").split(',');
var parts = $('#parts');
// set target index for elements
$.each(partsOrder, function(i, v){
$('.' + v, parts).data('index', i);
});
// sort array on index
var items = parts.find('.part');
items.sort(function(a,b){ return $(a).data('index') - $(b).data('index'); });
// move elements into array order
parts.append(items);
答案 1 :(得分:0)
这假设您正在循环并在div中创建多个三组,并且不需要您编辑HTML。
var input = $('#control input');
var partsOrder = input.attr("data-order");
var parts = $('#parts');
var partsArray = partsOrder.split(',');
var $part = parts.find('.part');
var groupNum = 0;
$part.each(function(k,v) {
if (k === 0 || k % 3 === 0) {
var $div = $(v).wrap('<div class="group" data-group="' + groupNum + '"></div>');
$(v).attr('data-group', groupNum);
var $second = $($part.get(k+1)).attr('data-group', groupNum);
var $third = $($part.get(k+2)).attr('data-group', groupNum);
$second.remove();
$third.remove();
$div.append($second);
$div.append($third);
groupNum++;
}
});
for (var i = 0; i < groupNum; i++) {
var $group = $('.group[data-group="' + i + '"]');
for (var j = 0; j < partsArray.length; j++) {
var $thePart = $group.find('.' + partsArray[j]);
$thePart.remove();
$group.append($thePart);
}
}
$('.group').unwrap();