如何使用dojo计算或总结Json中的不同值

时间:2010-02-16 08:55:35

标签: javascript json dojo arcgis-server

我从ArcGIS服务器获得了一个Json响应,如下所示:

{  "displayFieldName" : "ELTTYPE", 
"features" : [
{
  "attributes" : {
    "ELTTYPE" : "Faldunderlag", 
    "DATANR" : 721301, 
    "ELEMENTNR" : 40, 
    "AREALTYPE" : "BELÆGNING", 
    "SHAPE.area" : 26.4595572
  }
}, 
{
  "attributes" : {
    "ELTTYPE" : "Prydplæne", 
    "DATANR" : 721301, 
    "ELEMENTNR" : 2, 
    "AREALTYPE" : "GRÆS", 
    "SHAPE.area" : 1993.23450096
  }
}, 
{
  "attributes" : {
    "ELTTYPE" : "Busket", 
    "DATANR" : 721301, 
    "ELEMENTNR" : 18, 
    "AREALTYPE" : "BUSKE", 
    "SHAPE.area" : 2105.69020834
  }
}...... and so on ]
}

我喜欢使用ELEMENTNR的不同值和SHAPE.area的summurized值创建一个datagrid。

有没有人知道如何做到这一点?

塞巴斯蒂安

2 个答案:

答案 0 :(得分:0)

请参阅Array.prototype.filter

您需要包含过滤器脚本代码段才能将其用于不受支持的浏览器。

function reduceMyData(input) {
  var check = {};
  return input.filter(function(item, index, ary){
    var id = item.attributes["ELEMENTNR"];
    if (check[id]) return false;
    return check[id] = true;
  });
}

var myFeatures = reduceMyData(data.features);

答案 1 :(得分:0)

据我所知,您不仅需要获取具有不同ELENTNR的元素,还需要为具有相同ELENTNR的元素累积SHAPE.area。如果是这样的话:

var codes = {};
// features - is an array of features from your json
var distinctFeatures = dojo.filter(features, function(m){
    if(typeof(codes[m.attributes.ELEMENTNR]) == "undefined"){
        codes[m.attributes.ELEMENTNR] = m.attributes["SHAPE.area"];
        return true;
    }
    else{ // if duplicate
        codes[m.attributes.ELEMENTNR] += m.attributes["SHAPE.area"];
        return false;
    }
});
for(var index in distinctFeatures){
    var elementNr = distinctFeatures[index].attributes.ELEMENTNR;
    distinctFeatures[index].attributes["SHAPE.area"] = codes[elementNr];
}
相关问题