如何使用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,但是当我运行该代码时,它变得完全静止。
答案 0 :(得分:0)
您正在错误地加载外部JSON:
而不是
d3.json("assets/data/nr-coordinate.json", function(data) {
正确的方法:
d3.json("assets/data/nr-coordinate.json", function(error, data) {
这就是它无法正常工作的原因。
参考docs