这是我从API获得的一些示例数据:
{
"Document": {
"Placemark": [
{
"name": " V5-MJW",
"address": "Aviation Road, Windhoek, Namibia",
"description": [],
"TimeStamp": {
"when": "2016-05-21T06:12:00-04:00"
},
"styleUrl": "#asset7541",
"Point": {
"coordinates": "17.0829055,-22.598271,743"
}
},
{
"name": "GSatMicro80149",
"address": "Unnamed Road, Lesotho",
"description": [],
"TimeStamp": {
"when": "2016-05-11T04:52:00-04:00"
},
"styleUrl": "#asset7543",
"Point": {
"coordinates": "27.5594894,-29.456703,1659"
}
}
]
}
}
这是我当前正在创建数组的代码:
var flightPlanCoordinates = [];
//data being the returned values from the API.
$.each(data.Document.Placemark, function () {
var location = this.Point.coordinates.split(',');
var loc = {lat: parseFloat(location[1]), lng: parseFloat(location[0])};
flightPlanCoordinates[this.name] == null ? flightPlanCoordinates[this.name] = [] : flightPlanCoordinates[this.name].push(loc);
});
我得到了很多具有相同名称的地标,我想将每个具有不同名称的地标拆分为不同的数组。
直到我尝试通过
flightPlanCoordinates
发动所有这些为止,我都尝试了以下操作:$.each(flightPlanCoordinates, function(index) {
}
但这不起作用,如果我记录
flightPlanCoordinates
的长度,结果为0,但是在Firefox Dev工具中,我可以在flightPlanCoordinates
内部看到正确的值。我将如何去做呢?有没有比我在这里做的更好的方法?
最佳答案
请更换
var flightPlanCoordinates = [];
至
var flightPlanCoordinates = {};
它应该是一个对象,因为您使用
flightPlanCoordinates[this.name]
这样的属性对其进行了设置,其中this.name
是字符串,而不是索引。