1

次のような 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 の集計値を使用してデータグリッドを作成するのが好きです。

これを行う方法を知っている人はいますか?

セバスチャン

4

2 に答える 2

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];
}
于 2010-02-18T10:45:56.403 に答える
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);
于 2010-02-16T09:21:56.747 に答える