乐闻世界logo
搜索文章和话题

How do you create a family tree in d3. Js ?

5 个月前提问
5 个月前修改
浏览次数22

1个答案

1

在使用d3.js创建家谱时,您可以遵循以下步骤:

1. 收集数据

首先,您需要确定家谱的数据结构。通常,这包括个人的姓名、生日、家庭关系等信息。数据可以以JSON格式存储,例如:

json
{ "name": "John Doe", "children": [ { "name": "Jane Doe", "children": [ {"name": "Jim Doe"}, {"name": "Jill Doe"} ] }, { "name": "Joe Doe" } ] }

2. 设计布局

d3.js提供多种布局来呈现树状或层次型数据。对于家谱,您可以使用 d3.tree()d3.cluster()布局,这两种布局都适合展示层次数据。

3. 创建SVG容器

在HTML文件中,您需要创建一个SVG容器来绘制家谱:

html
<svg width="960" height="600"></svg>

4. 绘制家谱

使用D3的数据绑定和绘图功能,将每个节点绑定到SVG元素并绘制它。您可能需要添加矩形、文本和连线等元素:

javascript
var tree = d3.tree() .size([height, width]); var nodes = d3.hierarchy(data); nodes = tree(nodes); var svg = d3.select("svg") .attr("width", width) .attr("height", height) .append("g") .attr("transform", "translate(40,0)"); var link = svg.selectAll(".link") .data(nodes.descendants().slice(1)) .enter().append("path") .attr("class", "link") .attr("d", function(d) { return "M" + d.y + "," + d.x + "C" + (d.y + d.parent.y) / 2 + "," + d.x + " " + (d.y + d.parent.y) / 2 + "," + d.parent.x + " " + d.parent.y + "," + d.parent.x; }); var node = svg.selectAll(".node") .data(nodes.descendants()) .enter().append("g") .attr("class", "node") .attr("transform", function(d) { return "translate(" + d.y + "," + d.x + ")"; }); node.append("circle") .attr("r", 10); node.append("text") .attr("dy", ".35em") .attr("x", function(d) { return d.children ? -13 : 13; }) .style("text-anchor", function(d) { return d.children ? "end" : "start"; }) .text(function(d) { return d.data.name; });

5. 添加交互

可以添加一些交互功能,如点击节点展开/折叠子树、拖动以重新组织家谱等。这可以通过添加事件监听器和相应的功能来实现:

javascript
node.on("click", function(d) { if (d.children) { d._children = d.children; d.children = null; } else { d.children = d._children; d._children = null; } update(d); });

示例项目

在我的一个项目中,我为客户开发了一个互动的家谱展示。通过使用d3.js,我们成功地实现了数据的动态加载和家谱视图的实时更新,为用户带来了直观并丰富的视觉体验。

2024年7月25日 19:15 回复

你的答案