D3.js SVG中d属性的值

发布于 2022-09-04 23:47:46 字数 818 浏览 30 评论 0

let tree = d3.tree().size([width, height]);
d3.json('treeData.json').get((error, data) => {

  let root = d3.hierarchy(data[0]);
  tree(root);

  chartGroup.selectAll('circle')
    .data(root.descendants())
    .enter().append('circle')
      .attr('cx',(d) => d.x)
      .attr('cy',(d) => d.y)
      .attr('r','5');
  chartGroup.selectAll('path')
    .data(root.descendants().slice(1))
    .enter().append('path')
      .attr('class', 'link')
      .attr('d',(d) => {return 'M'+d.x+','+d.y+'C'+d.x+','+(d.parent.y+d.y)/2+' '+d.parent.x+','+(d.y+d.parent.y)/2+' '+d.parent.x+','+d.parent.y;});
})

图片描述

上面代码中最后一行的d属性怎么理解?为什么要这么写才能输出结点之间的曲线?C和M等分别代表了什么?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

三生殊途 2022-09-11 23:47:46

d是路径描述,M是Moveto,移动到,C是Curveto,表示贝塞尔曲线 参考:https://developer.mozilla.org...

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文