- 不要
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);
}