在数值上对嵌套数组进行排名

时间:2012-11-05 21:15:48

标签: javascript jquery arrays multidimensional-array

我对这个主题的第一个问题得到了回答,它帮助我继续前进,所以我很抱歉,如果这看起来像是重复的话。我从第一个例子开始向前移动,现在我正在尝试根据嵌套数组的每个元素中postion(1)的值对嵌套数组中的元素进行排序。以下适用于数字数组。

function mySorting(a, b) {
    return a == b ? 0 : (b < a ? -1 : 1)
}

var myArray = [28, 92, 12, 12, 2];
myArray.sort(mySorting);

var ranks = $.grep(myArray, function(item, idx) {
    return item != myArray[idx - 1];
}).reverse();



$.each(myArray, function(idx, item) {
    var rank= $.inArray( item, ranks)+1;
    $('body').append('Rank of '+item+ ' is '+ rank+'<br>')

})​

我的问题是当我将数组更改为:

var myArray = [["textA",28], ["textB",92], ["textC",12], ["textD",12], ["textE",2]];

我的排序功能不再有效。任何人都可以帮助我或指出我正确的方向吗?我想根据每个嵌套元素中的数字值对“myArray”进行排序。

再次提前感谢。

1 个答案:

答案 0 :(得分:0)

传递给排序函数的参数是要排序的数组中包含的任何内容。您的新数组包含两个元素的数组,因此在对数组进行排序时,排序函数将会收到这些数组。

你说你想根据它们的第二个元素对两元素数组进行排序。为此,您应该将排序功能更改为:

function mySorting(a, b) {
    return a[1] == b[1] ? 0 : (b[1] < a[1] ? -1 : 1)
}

编辑:如果要为具有相同第二个元素的所有数组分配相同的排名,则还需要修改其余代码,以便在比较数组时仅考虑第二个元素。实际上,保持排序原样可能是最容易的,但在排列数组之前只丢弃第二个元素:

function toSortKey(item) {
    return item[1];
}

function mySorting(a, b) {
    return a == b ? 0 : ( b < a ? -1 : 1 );
}

var myArray = [["textA",28], ["textB",92], ["textC",12], ["textD",12], ["textE",2]];

var sortKeys = $.map(myArray, toSortKey);
sortKeys.sort(mySorting);

var ranks = $.grep(sortKeys, function(item, idx) {
    return item != sortKeys[idx - 1];
}).reverse();

$.each(myArray, function(idx, item) {
    var rank = $.inArray( toSortKey(item), ranks ) + 1;
    $('body').append('Rank of ' + item + ' is ' + rank + '<br>')
})​;