本文介绍如何仅使用HTML和JavaScript创建类似鱼骨图的图表,无需依赖外部图形库如G6。 目标是创建一个多层级、自适应大小、并支持文本显示的鱼骨图,类似于示例图片所示的复杂图表。以下代码实现了大部分功能,并指出了可进一步优化的方向。
代码利用HTML5的SVG元素进行绘图,数据采用JSON格式存储,方便修改和扩展。 核心代码围绕一个名为fishbone
的类,负责图表的绘制和布局。
基本代码结构如下:
自适应鱼骨图
代码首先定义SVG画布,然后fishbone
类负责绘制。该类包含多个方法,例如main
方法初始化和渲染;initkvarray
计算节点宽度;randermonthbox
绘制节点框;randerfirstcircle
绘制一级子节点;creatbigcircle
递归绘制后续层级;getlinewidth
计算文本宽度;getmaxchildheight
计算子集最大高度;createtag
简化SVG元素创建;以及createmonth
、renderparent
和randerleaf
分别绘制节点框、父节点和叶子节点。
代码已实现节点宽度和文字长度的自适应,以及大部分布局逻辑。 然而,为了增强图表功能,建议读者添加以下功能:
通过完善这些功能,可以构建一个更强大灵活的鱼骨图绘制工具。 代码中使用自定义函数gettextwidth
计算文本宽度,提高了文本渲染精度。