这是我从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是字符串,而不是索引。

09-25 21:35