在javascript中从数组生成多级对象

在javascript中从数组生成多级对象,javascript,arrays,Javascript,Arrays,我有一个事件数组,我想在这些数组的对象之间建立关系。 数组: 我知道我想让这种关系 { "area": "punjab", "site": [ { "name": "lahore", "link": [ { "name": "http://sargodha.com", } ] }, { "name": "sargodha", "link": [

我有一个事件数组,我想在这些数组的对象之间建立关系。 数组:

我知道我想让这种关系

 {
  "area": "punjab",
  "site": [
    {
      "name": "lahore",
      "link": [
        {
          "name": "http://sargodha.com",
        }
      ]
    },
   {
      "name": "sargodha",
      "link": [
        {
          "name": "http://sargodha.com",
        }
      ]
    }
  ]
},
{
  "area": "sindh",
  "site": [
    {
      "name": "karachi",
      "link": [
        {
          "name": "http://karachi.com",
        }
      ]
    }
}
这是我写的代码:

    function isinarrayfilters(matchingObject, targetArray, key) {
    var existindex = -1;
    $.each(targetArray, function(index, array) {
        if (array.key == matchingObject.key) {
            //Object exist in array
            existindex = index;
        }
    });
    return existindex;
}

generatedRelationArray = [];
        $.each(alertsJson, function(index, alertJson) {
            inarrayindex = isinarrayfilters(alertJson.area, relationArray,'area');
            if (inarrayindex == -1) {
                key = alertJson.site
                generatedsites = {
                    "area": alertJson.area,
                    "site": []
                }
                relationArray.push(generatedsites);
            }
        });
了解任何人指导我如何将站点附加到相关区域

  • 我必须再次运行循环,尝试检查exist方法并获取索引,然后将站点推入其中
您可以使用

假设原始数组存储在
数据中

var res = data.groupBy(function(e){ return e.area; });
这将创建一个稍微不同的结构:

{
  "punjab" : [{
     'area': 'punjab',
     'site': 'lahore',
     'link': 'http: //lahore.com'
   }, {
     'area': 'punjab',
     'site': 'sargodha',
     'link': 'http: //sargodha.com'
   }, {
     'area': 'punjab',
     'site': 'multan',
     'link': 'http: //multan.com'
  }],
 "sindh": [...]
}
如果您需要这个显式结构,那么您可以这样做

var res = data.groupBy(function(e){ return e.area; })
              .each(function(e){
                  return {
                           area : e.key,
                           site : e.value.select(function(e){
                                return {
                                     name : e.site,
                                     linkm : [e.link]
                                };
                           });
              });

我已经创建了一个用于解释什么是查询js以及如何使用它的示例

一个保留格式的答案:

var generate = function(list) {
  var resultList = [];
  var tmpStoreRef = {};

  $.each(list, function(id, item) {
    var area = item.area
        ,site = item.site
        ,link = item.link;
    if (typeof tmpStoreRef[area] === 'undefined') {
      tmpStoreRef[area] = {
        area: area,
        site: []
      }
      resultList.push(tmpStoreRef[area]);
    }
    tmpStoreRef[area].site.push({
      name: site,
      link: link
    });
  });

  return resultList;
};
var generate = function(list) {
  var resultList = [];
  var tmpStoreRef = {};

  $.each(list, function(id, item) {
    var area = item.area
        ,site = item.site
        ,link = item.link;
    if (typeof tmpStoreRef[area] === 'undefined') {
      tmpStoreRef[area] = {
        area: area,
        site: []
      }
      resultList.push(tmpStoreRef[area]);
    }
    tmpStoreRef[area].site.push({
      name: site,
      link: link
    });
  });

  return resultList;
};