4

我正在尝试使用 .enter 方法生成 html。

我有以下代码:

alert(d3.select(".ul_class").length);
d3.select(".ul_class").data([4, 8, 15]).enter().append("li").text("hello");

第一个警报显示“1”,因此正确选择了对象。第二行没有在我的 DOM 对象中附加“li”元素。

我究竟做错了什么?谢谢

4

1 回答 1

8

您必须首先创建一个(空的)li元素选择:

d3.select(".ul_class")
  .selectAll('li') // <--
  .data([4, 8, 15]).enter().append("li").text("hello");

然后将数据绑定到该空选择,这将在选择中为新数据生成占位符。

所以你基本上是在说:

“选择所有li元素并将数据绑定[4, 8, 15]到它们。对于尚未绑定的所有数据项,创建一个新li元素。”

演示

于 2012-05-22T15:39:35.953 回答