繁体   English   中英

如何使用d3.js从外部json文件中读取特定属性?

[英]How to read specific attribute from external json file using d3.js?

如何使用d3加载外部json文件并从文件中选择特定属性以进行可视化。 我当前正在使用的代码。

d3.json("assets/data/nr-coordinate.json", function(data) {
        var overlay = new google.maps.OverlayView();

        overlay.onAdd = function() {
            var layer = d3.select(this.getPanes().overlayLayer).append("div")
                    .attr("class", "students");

            overlay.draw = function() {
                var projection = this.getProjection(),
                        padding = 10;
                var marker = layer.selectAll("svg")
                        .data(d3.entries(data.students))  
                        .each(transform) 
                        .enter().append("svg:svg")
                        .each(transform)
                        .attr("class", "marker");

                marker.append("svg:circle")
                        .attr("r", 25)
                        .attr("cx", padding + 7)
                        .attr("cy", padding + 7);

                function transform(d) {
                    d = new google.maps.LatLng(d.value.coordinate[0], d.value.coordinate[1]);
                    d = projection.fromLatLngToDivPixel(d);
                    return d3.select(this)
                            .style("left", (d.x - padding) + "px")
                            .style("top", (d.y - padding) + "px");
                }
            };
        };
    overlay.setMap(map);
});

样本数据集

{
    "students": [
{ "sex": "M", "level":2, "faculty":"FSKM", "coordinate": [2.218773,102.4543398]},
...]}

当我尝试将圆圈添加到Google地图中时,它无法解决问题。 我已经将zoomcontrol设置为true,但是当我运行该代码时,它变得完全静态。

您正在错误地加载外部JSON:

代替

d3.json("assets/data/nr-coordinate.json", function(data) {

正确方法:

d3.json("assets/data/nr-coordinate.json", function(error, data) {

这就是它不起作用的原因。

参考文档

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM