我有一个场景,我想使用数据连接为每个数据元素追加2个新元素.
我原来是这样做的:
var y = d3.selectAll("line")
.data([123, 456]);
y.enter().append("line"); // assume attr and style set
y.enter().append("line");
y.transition()...
Run Code Online (Sandbox Code Playgroud)
在我仔细考虑之前,我期待在我的转换中使用的更新选择将包含来自输入选择的合并附加.但当然这没有用,因为每个数据元素的选择只有1个插槽.
所以我更改了代码,使得它仍然使用相同的enter()选择两次,然后重新选择新元素以进行转换.
这种方法有效,但我的问题是这是否是推荐的方法.我追加/插入后应该确保停止使用enter()吗?或者可以使用它来创建多个元素,只要我记得更新选择只包含最后创建的元素吗?
如果事实证明这是错误的,那么实现这一目标的更好方法是什么?
mbo*_*ock 58
否.数据连接的目的是使元素与数据同步,根据需要创建,删除或更新元素.如果两次创建元素,则元素将不再与绑定的数据数组一一对应.
如果希望两个元素对应于每个数据,则首先附加一个组(G)元素以建立从数据到元素的一对一映射.然后根据需要附加子元素.结果结构如下:
<g>
<line class="line1"></line>
<line class="line2"></line>
</g>
<g>
<line class="line1"></line>
<line class="line2"></line>
</g>
Run Code Online (Sandbox Code Playgroud)
例如:
var g = svg.selectAll("g")
.data([123, 456]);
var gEnter = g.enter().append("g");
gEnter.append("line").attr("class", "line1");
gEnter.append("line").attr("class", "line2");
Run Code Online (Sandbox Code Playgroud)