gpt4 book ai didi

javascript - 无法在 d3 中制作包布局?全选不起作用?

转载 作者:行者123 更新时间:2023-12-02 15:40:00 26 4
gpt4 key购买 nike

我对编码比较陌生,对 d3 也很陌生。我目前正在尝试使用 d3 和 json 来制作一个包布局,代表当前的总统候选人以及他们在反馈期间谈论某个问题的次数。

我想从小处开始,所以我在 .json 文件中制作了一些虚拟数据,如下所示:

{
"name": "John Doe",
"party": "democratic",
"issues": [
{ "issue":"issue1", "value": 25 },
{ "issue":"issue2", "value": 10 },
{ "issue":"issue3", "value": 50 },
{ "issue":"issue4", "value": 40 },
{ "issue":"issue5", "value": 5 }
]
}

我想显示以“问题”为标签、以“值”为圆半径的气泡,最终在 Canvas 上显示五个不同大小的圆圈。下面是我的index.html 文件:

var width = 800, height = 600;

var canvas = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(50, 50)");

var pack = d3.layout.pack()
.size([width, height - 50])
.padding(10);

d3.json("fakedata.json", function (data) {

var nodes = pack.nodes(data);

var node = canvas.selectAll(".node")
.data(nodes)
.enter()
.append("g")
.attr("class", "node")
.attr("transform", function (d) {
return "translate(" + d.x + "," + d.y + ")";
});

node.append("circle")
.attr("r", function (d) { return d.r; })
.attr("fill", "steelblue")
.attr("opacity", 0.25)
.attr("stroke", "#ADADAD")
.attr("stroke-width", "2");

node.append("text")
.text(function (d) {
return d.children ? "" : d.issue;
});
});

我不断收到下面的错误,我认为这是因为节点设置不正确。

 Error: Invalid value for <g> attribute transform="translate(NaN,NaN)"
Error: Invalid value for <circle> attribute r="NaN"

任何帮助将不胜感激!谢谢你!

最佳答案

您传递的 JSON 是

{
"name": "John Doe",
"party": "democratic",
"issues": [
{ "issue":"issue1", "value": 25 },
{ "issue":"issue2", "value": 10 },
{ "issue":"issue3", "value": 50 },
{ "issue":"issue4", "value": 40 },
{ "issue":"issue5", "value": 5 }
]
}

应该如下所示,注意键名children而不是issues

{
"name": "John Doe",
"party": "democratic",
"children": [
{ "issue":"issue1", "value": 25 },
{ "issue":"issue2", "value": 10 },
{ "issue":"issue3", "value": 50 },
{ "issue":"issue4", "value": 40 },
{ "issue":"issue5", "value": 5 }
]
}

工作代码here .

关于javascript - 无法在 d3 中制作包布局?全选不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32663151/

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