gpt4 book ai didi

javascript - d3.selectAll().data(myDataSet).enter().append ("rect") 正在选择先前创建的矩形而不是 myDataSet

转载 作者:行者123 更新时间:2023-11-30 10:21:22 25 4
gpt4 key购买 nike

我是 d3.js 的新手,目前我正在从事一个需要 d3.js 的项目。我遇到了一个问题,需要帮助/指导来解决这个问题。

问题是在我的 svg 容器中,我有 2 个硬编码的矩形 [使用 svg.append("rect") 创建]。

现在我有一个 json 数据集,它有 2 个数据来创建另外 2 个矩形[ 运行时 json 中可能有更多数据,这是静态示例]。

现在,当我使用以下代码时,它只会创建 1 个矩形。

注意 svg 上的 selectAll 函数选择其他 2 个先前创建的矩形,并且仅动态创建额外的 1 个矩形(json 中的 3 个 - 2 个硬编码矩形 = 1 个已创建的矩形)。

但我希望 json 中的所有 data (3) 都应该创建一个矩形,即 3 rectangle 应该由 Json 创建并且硬编码的矩形应该保持原样是。

但它并没有这样做,我已经在这篇文章中添加了 html 代码。这是我到目前为止尝试过的 javascript 和 HTML。

请帮忙。

<html>
<head>
<meta charset="ISO-8859-1">
<title>D3 Test</title>
<script type="text/javascript" src="d3/d3.v3.min.js"></script>
</head>
<body>
<h1>hello....</h1>
<div id="chartDiv">
</div>
<script type="text/javascript">
var w = 1000;
var h = 400;
var svgContainer = d3.select("#chartDiv").append("svg").attr("width", w).attr("height", h);

var call_result_dataset = [{"x_axis":40, "y_axis":10, "width":5, "height":110, "color":"green"},
{"x_axis":700, "y_axis":10, "width":5, "height":110, "color":"red"},
{"x_axis":760, "y_axis":10, "width":5, "height":110, "color":"red"}];

var call_result_strip = svgContainer.append("rect")
.attr("id", "call_result_strip")
.attr("x", 10)
.attr("y", 10)
.attr("width", 980)
.attr("height", 110)
.attr("fill", "rgb(235,235,235)");

var call_type_strip = svgContainer.append("rect")
.attr("id", "call_type_strip")
.attr("x", 10)
.attr("y", 200)
.attr("width", 980)
.attr("height", 110)
.attr("fill", "rgb(235,235,235)");



var call_result_strip_bars = svgContainer.selectAll("rect")
.data(call_result_dataset)
.enter()
.append("rect");

var all_r_strip = call_result_strip_bars.attr("x", function(d){ return d.x_axis;})
.attr("y", function(d){ return d.y_axis;})
.attr("width", function(d){ return d.width;})
.attr("height", function(d){ return d.height;})
.attr("fill", function(d){ return d.color;})
.attr("id", function(d,i) {return "result_"+i;});

</script>
</body>
</html>

最佳答案

您可以使用以下代码段:

svgContainer.selectAll(".dynamicRects")
.data(call_result_dataset)
.enter()
.append("rect")
.addClass('dynamicRects')
...

这样,输入选择将首先为空,然后将创建三个动态矩形。

关于javascript - d3.selectAll().data(myDataSet).enter().append ("rect") 正在选择先前创建的矩形而不是 myDataSet,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21376393/

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