4

私はこのようないくつかの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 属性で並べ替えられるようにするにはどうすればよいでしょうか?

例: 3、4、4.5、5

4

3 に答える 3

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');
};
于 2012-04-05T02:48:53.370 に答える
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/

于 2012-04-05T02:10:51.450 に答える
0

DOM メソッドで要素を選択し、DOM リストを配列に変換してから を使用できますArray.sort()

于 2012-04-04T23:57:26.163 に答える