Order Divs基于Jquery中的属性值

时间:2012-04-04 23:51:45

标签: jquery

我有几个像这样的div

<div rel="5">
  Divs content goes here
</div>
<div rel="3">
   Div 3 Here
</div>
<div rel="4">
  Div 4 Here
 </div>
 <div rel="4.5">
   Div 4.5 here
</div>

你如何使用Jquery对div进行排序,以便在DOM中物理上使用最少的rel属性进行排序?

e.g。 3,4,4.5,5

3 个答案:

答案 0 :(得分:12)

看我的小提琴:http://jsfiddle.net/6hpNz/8/

您可以利用javascript和jQuery的组合来轻松完成此任务:

给出以下HTML:

<div class="unsorted">
    <div rel="5">
      Div 5 here
    </div>
    <div rel="3">
       Div 3 Here
    </div>
     <div rel="4.5">
       Div 4.5 here
    </div>
    <div rel="4">
      Div 4 Here
     </div> </div>
<div class="sorted"></div>

此脚本将为您提供所需的输出:

$(document).ready(function () {
    var sortedDivs = $(".unsorted").find("div").toArray().sort(sorter);
    $.each(sortedDivs, function (index, value) {
        $(".sorted").append(value);
    });
});

function sorter(a, b) {
    return a.getAttribute('rel') - b.getAttribute('rel');
};

答案 1 :(得分:1)

我确信有一种更有效的方法,但无论如何,这是我的答案:

HTML:

<div rel="5">
      Divs content goes here
    </div>
    <div rel="3">
       Div 3 Here
    </div>
    <div rel="4">
      Div 4 Here
     </div>
     <div rel="4.5">
       Div 4.5 here
    </div>

jQuery的:

var array = new Array();

$('div').each(function(){   
    array.push($(this).attr('rel'));
});

array = array.sort();

var reordedDivs = "";

$.each(array, function(i, obj1){

    $('div').each(function(j, obj2) {

        if ($(obj2).attr('rel') == obj1) {

            var divContent = $(obj2).html();
            var rel = obj1;

         reordedDivs += "<div rel='" + rel + "'>" + divContent + "</div>";

        }

            });  
});

$('body').html(reordedDivs);

小提琴:http://jsfiddle.net/F6csV/17/

答案 2 :(得分:0)

您可以使用DOM方法选择元素,将DOM列表转换为Array,然后使用Array.sort()