如何从该数组中的值获取特定的JSON数组

时间:2015-04-11 04:27:00

标签: javascript json d3.js

我是d3.js和JSON的新手。我正在通过做一些小的可视化来学习。现在,我正在尝试加载JSON数据并根据国家/地区代码可视化详细信息。

我的JSON数据如下:

[
  {
    "Id":"SWE",
    "Country":"Sweden",
    "Population":9592552
  },
  {
    "Id":"NOR",
    "Country":"Norway",
    "Population":5084190
  },
.
.
.
]

我有世界国家地理JSON,我可以成功地进行可视化,并且还能够突出显示所选国家/地区并获得所选国家/地区的ID。现在我需要根据我从选择中获得的ID获取详细信息(该国家/地区的人口和国家/地区名称)。有人可以告诉我如何从JSON数组中获取值。

我试过

 population = data.map( function(d) { return d["Population"] });

但是这个给了我整个人群作为一个数组。如何根据Id获得SWE的人口?

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <script src="http://d3js.org/d3.v3.min.js"></script>
    <style>
    </style>
    <script type="text/javascript">

        var data;

        function draw(geo_data) {
            "use strict";
            var margin = 75,
                    width = 1400 - margin,
                    height = 600 - margin;

            var svg = d3.select("body")
                    .append("svg")
                    .attr("width", width + margin)
                    .attr("height", height + margin)
                    .append('g')
                    .attr('class', 'map');

            var projection = d3.geo.mercator()
                    .scale(150)
                    .translate( [width / 2, height / 1.5]);

            var path = d3.geo.path().projection(projection);

            var map = svg.selectAll('path')
                    .data(geo_data.features)
                    .enter()
                    .append('path')
                    .attr('d', path)
                    .style('fill', 'lightBlue')
                    .style('stroke', 'black')
                    .attr("id", function(d) {
                        return d.id; })
                    .on("click", function(d, i) {

                        d3.select(".selected").classed("selected", false).style('fill', 'lightBlue');
                        d3.select(this).classed("selected", true).style('fill', 'red');
                        console.log(d.id)
                        display(d.id)

                    })
                    .style('stroke-width', 0.5);

        };

        d3.json("data/wrangledData_overallScore.json", function (error, json) {
            if (error) return console.warn(error);
            data = json;
            console.log("JSON", data);
        });

        function display(e){
           var population = data.map( function(d) { return d["Population"] });
            console.log(population)
        }

    </script>
</head>
<body>
<script type="text/javascript">
    /*
     Use D3 to load the GeoJSON file
     */

    d3.json("data/world-countries.json", draw);
</script>
</body>
</html>

我可以获取id的索引并使用它来查找population数组中的种群。但我需要根据Id找到。有人可以告诉我怎样才能得到这个。

2 个答案:

答案 0 :(得分:4)

首先,由于您是JSON的新手,可以通过一些术语修正来帮助您:JSON是一个字符串而不是一个对象,因此它的缩写 J ava S 阻止 O 对象 N otation。您所拥有的通俗地称为POJO或 P lain O ld J avascript O 对象。他们是不同的。

现在提出你的问题。你有两种方法:

  1. 您可以使用poly-fill来制作即将推出的ECMA 6数组方法,以及将来证明您的答案
  2. 或者您可以使用ECMA 5功能推出自己的解决方案
  3. 第一种解决方案是使用find文档中提供的填充:

    var countryData = data.find(function(element, index, array) {
      return element.Id === 'SWE';
    });
    
    countryData.Population // 9592552
    

    第二种方法基本上是以您选择的任何方式重新创建多边形填充,如果您选择该选项,我会将其留给您作为练习来学习。

    &#13;
    &#13;
    if (!Array.prototype.find) {
      Array.prototype.find = function(predicate) {
        if (this == null) {
          throw new TypeError('Array.prototype.find called on null or undefined');
        }
        if (typeof predicate !== 'function') {
          throw new TypeError('predicate must be a function');
        }
        var list = Object(this);
        var length = list.length >>> 0;
        var thisArg = arguments[1];
        var value;
    
        for (var i = 0; i < length; i++) {
          value = list[i];
          if (predicate.call(thisArg, value, i, list)) {
            return value;
          }
        }
        return undefined;
      };
    }
    
    var data = [{
      "Id": "SWE",
      "Country": "Sweden",
      "Population": 9592552
    }, {
      "Id": "NOR",
      "Country": "Norway",
      "Population": 5084190
    }];
    
    function display(e) {
      console.log("E", e);
      var countryData = data.find(function(element, index, array) {
        return element.Id === e;
      });
      console.log(countryData.Population);
    }
    
    display('SWE');
    &#13;
    &#13;
    &#13;

答案 1 :(得分:1)

直到你看到正确的id为止。

for (var i in data) {
    if (data[i].Id == 'SWE') console.log(data[i]['Population']);
}

你也可以使用while循环或常规for循环。这里每个i&#34;键&#34;在测试数据时,每个数据都是data[i]