为了账号安全,请及时绑定邮箱和手机立即绑定

d3 不会在第一次运行时附加圆圈

d3 不会在第一次运行时附加圆圈

神不在的星期二 2022-12-29 13:52:48
我正在使用嵌套数据集和以下代码在 d3 v5 中绘制圆圈:const scatterGroup = svg.selectAll(".scatterGroup").data(data);scatterGroup.exit().remove();scatterGroup  .enter()  .append("g")  .attr("class", "scatterGroup")  .attr("fill", (d, i) => color[i])  .attr("stroke", (d, i) => color[i])  .append("g")  .attr("class", "scatterPoints");const scatterPoints = scatterGroup  .selectAll(".scatterPoints")  .data((d) => d);scatterPoints  .enter()  .append("circle")  .attr("class", "scatterPoints")  .attr("cx", (d, i) => xScale(d.x))  .attr("cy", (d, i) => yScale(d.y))  .attr("r", 5);scatterPoints.exit().remove();const scatterUpdate = scatterGroup  .transition()  .duration(500)  .attr("fill", (d, i) => color[i])  .attr("stroke", (d, i) => color[i]);scatterPoints  .transition()  .duration(500)  .attr("cx", (d, i) => xScale(d.x))  .attr("cy", (d, i) => yScale(d.y));在提供数据的第一次运行中没有任何反应。控件在第一次加载时未到达追加圆圈。第二次加载数据时,d3 附加圆圈。谁能告诉我如何在首次提供数据时让它们出现以及为什么会这样?
查看完整描述

1 回答

?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

这是因为数据是嵌套的,所以你需要.merge() scatterGroup 或者在创建之前重新选择它scatterPoints。否则,scatterGroup仍然是空的,而scatterGroup.enter()持有所有的点。


我还.append(g).attr('class', 'scatterPoints')从您的代码中删除了,因为它使用 ag而不是 acircle并且不需要存在


const svg = d3.select('svg');

const color = ['red', 'blue'];

const data = [

  [{

    x: 10,

    y: 10

  }, {

    x: 40,

    y: 100

  }],

  [{

    x: 25,

    y: 50

  }]

];

const newData = [

  [{

    x: 10,

    y: 20

  }, {

    x: 50,

    y: 100

  }],

  [{

    x: 25,

    y: 40

  }]

];


function draw(data) {

  const scatterGroup = svg.selectAll(".scatterGroup").data(data);


  scatterGroup.exit().remove();


  const scatterGroupNew = scatterGroup

    .enter()

    .append("g")

    .attr("class", "scatterGroup")

    .attr("fill", (d, i) => color[i])

    .attr("stroke", (d, i) => color[i]);


  // Equivalent:

  //const scatterPoints = svg.selectAll(".scatterGroup")

  //  .selectAll(".scatterPoint")

  //  .data((d) => d);


  const scatterPoints = scatterGroup

    .merge(scatterGroupNew)

    .selectAll(".scatterPoint")

    .data((d) => d);


  scatterPoints.exit().remove();


  const scatterPointsNew = scatterPoints

    .enter()

    .append("circle")

    .attr("class", "scatterPoint")

    .attr("r", 5);


  scatterPoints.merge(scatterPointsNew)

    .attr("cx", (d, i) => d.x)

    .attr("cy", (d, i) => d.y);

}


draw(data);

setTimeout(() => draw(newData), 1000);

<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"></script>


<svg>

</svg>


查看完整回答
反对 回复 2022-12-29
  • 1 回答
  • 0 关注
  • 73 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信