首页 web前端 css教程 如何使用原生JavaScript绘制复杂的、可定制的鱼骨图?

如何使用原生JavaScript绘制复杂的、可定制的鱼骨图?

Apr 05, 2025 pm 05:42 PM
排列

如何使用原生JavaScript绘制复杂的、可定制的鱼骨图?

原生JavaScript绘制复杂鱼骨图详解

本文介绍如何使用纯JavaScript代码绘制复杂的、可定制的鱼骨图,无需借助第三方库如G6。我们将深入探讨代码实现,并指出代码中尚待完善的部分。

文章基于一个用户提供的复杂鱼骨图示例(见上图),该图包含多级子节点和节点文本信息,因此选择原生SVG绘制方式,直接在HTML中创建SVG元素构建鱼骨图,以获得更高的灵活性。

代码首先定义一个JSON数据结构arr,存储鱼骨图的节点和连接关系。每个节点包含label(标签)、value(值)、type(类型)、time(时间)和child(子节点)等属性。 核心部分是FishBone类,负责解析数据并使用SVG元素进行绘制。

FishBone类包含以下关键方法:

  • initKvArray():遍历数据,计算每个月份节点的宽度,并存储在kvArray中。宽度根据子节点中最长文本长度自适应调整。
  • getMaxWidth():递归计算每个节点及其子节点中最长文本宽度,确定节点宽度。
  • randerMonthBox():绘制月份节点(平行四边形)及其文本。月份节点的x坐标根据前一个节点宽度累加计算。
  • creatBigCircle():绘制主干节点(圆圈)和连接线,并递归调用renderParent()绘制子节点。
  • renderParent():递归绘制子节点,并计算子节点高度。
  • randerLeaf():绘制最底层叶子节点。
  • getMaxChildHeight():递归计算每个节点的最大子节点数量,确定子节点排列方式。
  • getLineWidth():计算文本宽度,设置最小宽度,确保线条足够长以容纳文本。
  • createTag():辅助函数,创建SVG元素。
  • createMonth():辅助函数,创建月份节点。

代码已实现大部分功能,包括月份节点宽度自适应、文本长度自适应以及基本图形绘制。但仍有以下待完善部分:

  • 子集展开/收缩功能: 允许用户展开或收缩子节点,提高交互性。
  • 线条颜色配置: 允许用户自定义线条颜色,增强视觉效果。
  • 整体收缩/展开功能: 允许用户一次性展开或收缩整个鱼骨图。
  • 图自适应大小功能: 根据内容自动调整鱼骨图大小,适应不同屏幕尺寸。
  • 节点事件绑定: 允许用户与节点交互,例如点击节点显示更多信息。

这些功能需要根据实际需求补充完善。代码已预留相关接口和变量,方便扩展。例如,可在arr数据中添加事件属性,并在创建元素时绑定事件监听器实现节点事件。

此代码提供了一个功能完善的鱼骨图基础,用户可根据自身需求进行定制和扩展,原生SVG的特性保证了灵活性与可控性。

以上是如何使用原生JavaScript绘制复杂的、可定制的鱼骨图?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1653
14
CakePHP 教程
1413
52
Laravel 教程
1304
25
PHP教程
1251
29
C# 教程
1224
24
Bootstrap图片居中需要用到flexbox吗 Bootstrap图片居中需要用到flexbox吗 Apr 07, 2025 am 09:06 AM

Bootstrap 图片居中方法多样,不一定要用 Flexbox。如果仅需水平居中,text-center 类即可;若需垂直或多元素居中,Flexbox 或 Grid 更合适。Flexbox 兼容性较差且可能增加复杂度,Grid 则更强大且学习成本较高。选择方法时应权衡利弊,并根据需求和偏好选择最适合的方法。

十大加密货币交易平台 币圈交易平台app排行前十名推荐 十大加密货币交易平台 币圈交易平台app排行前十名推荐 Mar 17, 2025 pm 06:03 PM

十大加密货币交易平台包括:1. OKX,2. Binance,3. Gate.io,4. Kraken,5. Huobi,6. Coinbase,7. KuCoin,8. Crypto.com,9. Bitfinex,10. Gemini。选择平台时应考虑安全性、流动性、手续费、币种选择、用户界面和客户支持。

十大虚拟币交易平台2025 加密货币交易app排名前十 十大虚拟币交易平台2025 加密货币交易app排名前十 Mar 17, 2025 pm 05:54 PM

十大虚拟币交易平台2025:1. OKX,2. Binance,3. Gate.io,4. Kraken,5. Huobi,6. Coinbase,7. KuCoin,8. Crypto.com,9. Bitfinex,10. Gemini。选择平台时应考虑安全性、流动性、手续费、币种选择、用户界面和客户支持。

网页批注如何实现Y轴位置的自适应布局? 网页批注如何实现Y轴位置的自适应布局? Apr 04, 2025 pm 11:30 PM

网页批注功能的Y轴位置自适应算法本文将探讨如何实现类似Word文档的批注功能,特别是如何处理批注之间的间�...

c上标3下标5怎么算 c上标3下标5算法教程 c上标3下标5怎么算 c上标3下标5算法教程 Apr 03, 2025 pm 10:33 PM

C35 的计算本质上是组合数学,代表从 5 个元素中选择 3 个的组合数,其计算公式为 C53 = 5! / (3! * 2!),可通过循环避免直接计算阶乘以提高效率和避免溢出。另外,理解组合的本质和掌握高效的计算方法对于解决概率统计、密码学、算法设计等领域的许多问题至关重要。

如何优雅地解决换行后Span标签间距过小的问题? 如何优雅地解决换行后Span标签间距过小的问题? Apr 05, 2025 pm 06:00 PM

如何优雅地处理换行后的Span标签间距在网页布局中,经常会遇到需要水平排列多个span...

安全靠谱的数字货币平台有哪些 安全靠谱的数字货币平台有哪些 Mar 17, 2025 pm 05:42 PM

安全靠谱的数字货币平台:1. OKX,2. Binance,3. Gate.io,4. Kraken,5. Huobi,6. Coinbase,7. KuCoin,8. Crypto.com,9. Bitfinex,10. Gemini。选择平台时应考虑安全性、流动性、手续费、币种选择、用户界面和客户支持。

安全的虚拟币软件app推荐 十大数字货币交易app排行榜2025 安全的虚拟币软件app推荐 十大数字货币交易app排行榜2025 Mar 17, 2025 pm 05:48 PM

安全的虚拟币软件app推荐:1. OKX,2. Binance,3. Gate.io,4. Kraken,5. Huobi,6. Coinbase,7. KuCoin,8. Crypto.com,9. Bitfinex,10. Gemini。选择平台时应考虑安全性、流动性、手续费、币种选择、用户界面和客户支持。

See all articles