-1

如果我有这样的数组

var cars=
[
      { 'title':'brand', 'value':'honda'}
      { 'title':'brand', 'value':'toyota'}
      { 'title':'color', 'value':'red'}
      { 'title':'color', 'value':'white'}
      { 'title':'year', 'value':'1995'}
      { 'title':'year', 'value':'2006'}
      { 'title':'year', 'value':'2007'}     
 ]

如何编写一个返回元素排名的函数。所以对于这个数组,对于标题为“brand”的元素,它应该返回 0,对于标题为“color”的元素,它应该返回 1,依此类推。它不应该缓存或使用任何映射表,但应该确定飞行中的排名,所以任何时候你打电话

getRank(cars[6]) == 2 //true for the last element 
getRank(cars[0]) == 0 //true for the first element 
getRank(cars[1]) == 0 //true for the second element 
getRank(cars[3]) == 1 //true for the fourth element 
4

2 回答 2

2

根据您的进一步解释更新答案

Javascript

var cars = [
      { 'title':'brand', 'value':'honda'},
      { 'title':'brand', 'value':'toyota'},
      { 'title':'color', 'value':'red'},
      { 'title':'color', 'value':'white'},
      { 'title':'year', 'value':'1995'},
      { 'title':'year', 'value':'2006'},
      { 'title':'year', 'value':'2007'}     
 ];

function getRank(data, number) {
    var ranks = {},
        rank = 0;

    data.forEach(function (entry) {
        if (typeof ranks[entry.title] !== "number") {
            ranks[entry.title] = rank;
            rank += 1;
        }
    });

    return ranks[data[number].title];
}


console.log(getRank(cars, 6));
console.log(getRank(cars, 0));
console.log(getRank(cars, 1));
console.log(getRank(cars, 3));

jsfiddle 上

输出

2
0
0
1
于 2013-05-16T22:06:24.607 回答
0

如果它已经订购(这一定是原因,否则我真的不明白你的问题)你可以做如下的事情

var current_index = -1;
var current_title = "";

for (var i in arr) {
    if (arr[i].title!=current_title) {
        current_title = arr[i].title;
        current_index++;
    }
    arr[i].rank = current_index;

}
于 2013-05-16T22:04:21.100 回答