我从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。
有没有人知道如何做到这一点?
塞巴斯蒂安
答案 0 :(得分:0)
您需要包含过滤器脚本代码段才能将其用于不受支持的浏览器。
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];
}