gpt4 book ai didi

javascript - 修改 d3.js 圆环图以从 json 数组读取

转载 作者:行者123 更新时间:2023-12-02 14:39:39 24 4
gpt4 key购买 nike

如何修改此示例以从 JSON 数组而不是 CSV 文件读取?我将有一个静态 JSON 字符串,我想将其用作“数据”而不是 CSV。任何指示将不胜感激。

var width = 960,
height = 500,
radius = Math.min(width, height) / 2;

var color = d3.scale.ordinal()
.range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);

var arc = d3.svg.arc()
.outerRadius(radius - 10)
.innerRadius(radius - 70);

var pie = d3.layout.pie()
.sort(null)
.value(function(d) { return d.population; });

var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

d3.csv("data.csv", type, function(error, data) {
if (error) throw error;

var g = svg.selectAll(".arc")
.data(pie(data))
.enter().append("g")
.attr("class", "arc");

g.append("path")
.attr("d", arc)
.style("fill", function(d) { return color(d.data.age); });

g.append("text")
.attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")"; })
.attr("dy", ".35em")
.text(function(d) { return d.data.age; });
});

function type(d) {
d.population = +d.population;
return d;
}

示例 JSON 数据:

[
{
"age": "<5",
"population": 2704659
},
{
"age": "5-13",
"population": 4499890
},
{
"age": "14-17",
"population": 2159981
},
{
"age": "18-24",
"population": 3853788
},
{
"age": "25-44",
"population": 14106543
},
{
"age": "45-64",
"population": 8819342
},
{
"age": "≥65",
"population": 612463
}
]

这是以下链接中的示例。 Original Example

最佳答案

真的,并没有太多变化。使用您提供的示例,只需定义一个名为 data 的 var 并将其分配给您的示例 JSON 数据:

var data = [
{
"age": "<5",
"population": 2704659
},
{
"age": "5-13",
"population": 4499890
},
...etc

然后屏蔽或删除第 53 行的 d3.csv() 行。一切正常。

这是给你的 fiddle :https://jsfiddle.net/ej2s217f/

关于javascript - 修改 d3.js 圆环图以从 json 数组读取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37119881/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com