在json数组中检索具有相同id的对象(javascript)

时间:2013-03-16 11:06:33

标签: javascript arrays json

我想在使用javascript

制作的json数组中检索具有相同id的对象
var Array = {               
    "1": {"text": "Number one", "time": "16 03 13"},
    "1": {"text": "Number two", "time": "14 03 13"},
    "1": {"text": "Number three", "time": "13 03 13"},
    "2": {"text": "Number one", "time": "13 03 13"},
};

我试过这种方式,但显然它只显示了第一个结果(第一个)

var get = Array[1]; 
alert(get.text);

我想到了一个循环,我该怎么办?

1 个答案:

答案 0 :(得分:8)

  • 请勿将Array用作变量名称。
  • 对象键不能重复。如果这样做,只有最新的条目被输入该密钥。其他人被丢弃了。在您的情况下,只能通过“1”键访问第三个“1”。
  • 您需要的是一个数组,而不是一个对象

你需要这个:

var myArray = [               
    {"id" : 1, "text": "Number one", "time": "16 03 13"},    //index 0
    {"id" : 1, "text": "Number two", "time": "14 03 13"},    //index 1
    {"id" : 1, "text": "Number three", "time": "13 03 13"},  //index 2
    {"id" : 2, "text": "Number one", "time": "13 03 13"}     //index 3
];

var i;

for(i=0;i<myArray.length;i++){
  if(myArray[i].id === 1){
    console.log(myArray[i].text);
  }
}

这是另一种方法,这需要重组您的数据。如果id为1的条目具有多个值,则可以在每个键下保留一个数组。

var myArray = {               
  "1" : [
    {"text": "Number one", "time": "16 03 13"},  //index 0
    {"text": "Number two", "time": "14 03 13"},  //index 1
    {"text": "Number three", "time": "13 03 13"} //index 2
  ],
  "2" : [
    {"text": "Number one", "time": "13 03 13"}   //index 0
  ]
};

var ones = myArray['1'];

for(i=0;i<ones.length;i++){
  console.log(ones[i].text);
}

另一种方法是使用Array.prototype.filter

var myArray = [               
  {"id" : 1, "text": "Number one", "time": "16 03 13"},    //index 0
  {"id" : 1, "text": "Number two", "time": "14 03 13"},    //index 1
  {"id" : 1, "text": "Number three", "time": "13 03 13"},  //index 2
  {"id" : 2, "text": "Number one", "time": "13 03 13"}     //index 3
];

//create an array containing only those with id of 1
var filtered = myArray.filter(function(val,i,arr){
  return val.id === 1;
});

for(i=0;i<filtered.length;i++){
  console.log(filtered[i].text);
}