基于X6的依赖关系图

需求

话不多说,直接上效果图!

简单来说,就是需要画出中心实体依赖的以及被依赖的关系图,并且能够切换中心实体且展示其依赖。

实现

第一步需要从x6官网找到贴合依赖的例子,最终选中的是Dagre布局,贴合依赖下游的场景,如下图:

解析官网实现:

ts 复制代码
const data: Model.FromJSONData = {
  nodes: [],//节点
  edges: [],//边
}
const edges = [ //左边👈:被依赖ID,右边👉:依赖的ID
  ['1', '2'],
  ['2', '3'],
  ['2', '4'],
  ['4', '5'],
  ['4', '6'],
  ['4', '7'],
  ['4', '8'],
  ['5', '9'],
  ['6', '10'],
  ['7', '11'],
  ['8', '12'],
]

for (let i = 1; i <= 12; i++) {
  data.nodes!.push({ //节点配置
    id: `${i}`,
    shape: 'circle',
    width: 32,
    height: 32,
    label: i,
    attrs: {
      body: {
        fill: '#5F95FF',
        stroke: 'transparent',
      },
      label: {
        fill: '#ffffff',
      },
    },
  })
}

edges.forEach((edge: [string, string]) => {
  data.edges!.push({ //边的关系配置
    source: edge[0], //连接的头
    target: edge[1],//连接尾
    attrs: {
      line: {
        stroke: '#A2B1C3',
        strokeWidth: 2,
      },
    },
  })
})

const graph = new Graph({
  container: document.getElementById('container')!,
})

const dagreLayout = new DagreLayout({
  type: 'dagre',
  rankdir: 'LR',
  align: 'UR',
  ranksep: 35,
  nodesep: 15,
})
const model = dagreLayout.layout(data)

graph.fromJSON(model)

主要是data的节点nodes配置和对应的边edges配置的整合,看懂了官网的实现,就只要思考以下三个问题:

1、实体节点之间的关系如何表示

2、如何自定义节点

3、如何自定义箭头以及连接路由

只要解决以上三个问题,那么慢慢就能实现啦。接下来就逐一分析吧~

实体节点之间的关系如何表示

我们认真看官网的示例代码,就能看出实现节点的关系其实是在设置边的关系,就是只需要设置好Edge的source和target,所以我们只需要把Edge整理成两部分,然后遍历设置就好啦:

中心实体依赖的: [中心实体,中心实体依赖的实体]、

依赖中心实体的:[依赖中心实体的实体,中心实体]

获取数据的接口数据格式如下:

arduino 复制代码
export const MOCK_DATA = {
  //中心实体
  bizEntity: {
  
  },
  //中心实体依赖的
  relatedBizEntities: [
  
   
  ],
  
   //依赖中心实体的
  beRelatedBizEntities: [
    
  ]
};

如何自定义节点

接下来就是节点的问题。官网上简单配置得到的节点显然不是需求所需要的样子。我们需要自定义节点,这样节点想写成什么样就写成什么样。 于是再找找节点的官网例子:找到啦找到啦使用antv/x6-react-shape库可以自定义node节点组件。这样问题就简单啦。

如何自定义连接线以及连接路由

我们看官网的例子的箭头不符合需求,所以就需要配置我们自己的箭头。从官网的例子可以看到,我们在定义边关系的时候,就有在设置边的样式配置,比如,stroke,strokeWidth等。所以我们就需要再从官网去寻找 自定义箭头,也就是设置sourceMarker和targetMarker的d属性,详情可见:自定义箭头path。再设置router就可以使连线更丝滑。

代码实现

详细代码前往: codepen

踩坑:

1、需要初始化画布之后再请求数据,请求数据之后再创建创建DagreLayout布局。

2、中心实体切换的时候需要重新初始化画布,将上一层的画布清空。(此代码未实现中心实体的切换)

总结

平常不怎么接触图形的实现,一开始会无从下手,多看看官网例子+官网API,大胆尝试,慢慢就能解决啦~

相关推荐
IT_陈寒1 分钟前
Vite 3.0 性能优化实战:5个技巧让你的构建速度提升200% 🚀
前端·人工智能·后端
金士顿3 分钟前
EC-Engineer SDK 核心 API 使用指南
前端
景彡先生17 分钟前
Python基础语法规范详解:缩进、注释与代码可读性
开发语言·前端·python
蓝创精英团队19 分钟前
C++DirectX9坐标系与基本图元之渲染状态(RenderState)_0304
前端·c++·性能优化
一天睡25小时23 分钟前
想偷卷?但微信不支持md文档?这个软件助你!
前端·javascript
艾小码24 分钟前
3个技巧让你彻底搞懂JavaScript异步编程
前端·javascript
Y42584 小时前
本地多语言切换具体操作代码
前端·javascript·vue.js
fruge6 小时前
React 2025 完全指南:核心原理、实战技巧与性能优化
javascript·react.js·性能优化
速易达网络7 小时前
Bootstrap 5 响应式网站首页模板
前端·bootstrap·html