5

我正在开发一个 web 应用程序,它需要动态绘制有根的 n 元树,以绘制技能之间的先决条件关系。它实际上已经这样做了,您可以在此处查看示例。不过,我正在尝试改进它,使用PyMag 中列出的算法,我必须承认,我在试图弄清楚如何使其适应我的 JavaScript 代码时有点迷失了。

编辑:这是我当前用于绘制这些树的代码,来自 Rails ERB 部分(我会在此处粘贴代码,但有点冗长)。

对于那些检查我的代码的人来说,gon.skills_map是一个这种格式的数组:

  • gon.skills_map[0] 是字符串中的技能标题
  • gon.skills_map[1] 是技能的URL,这样每个节点都是可点击的
  • gon.skills_map[2] 是一个后置条件数组(我称之为先决条件的反面)数组,格式完全相同
  • gon.skills_map[3] 是先决关系的等级(影响线条粗细)
4

1 回答 1

3

您可以使用 d3.js 数据可视化库。它比手动构建树要好得多,尤其是当图形变得更复杂时。d3 使用 svg,因此您可以与图形进行丰富的交互,例如单击、悬停、拖动等。

您需要将图形转换为适当的数据结构,如下所示:

{
  title: 'Skill A',
  url: 'http://skilla.com',
  children: [
    {
      title: 'Skill B',
      url: 'http://skillb.com',
      rating: 3,
      children: [
        {
          title: 'Skill D',
          url: 'http://skilld.com',
          rating: 5
        }, 
        {
          title: 'Skill E',
          url: 'http://skilld.com',
          rating: 10
        }
      ]
    },
    {
      title: 'Skill C',
      url: 'http://skillc.com',
      rating: 1
    }
  ]
}

这里的评级显示了对父技能的依赖程度。我在这个小提琴http://jsfiddle.net/atrniv/y8drq/2/中用 d3 创建了一个示例技能树

此外,如果您可以选择 d3,您可以从相同的技能依赖数据集创建多个不同的可视化。

d3 网站 - http://d3js.org/

于 2013-02-02T16:22:09.673 回答