基于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,大胆尝试,慢慢就能解决啦~

相关推荐
光影少年6 分钟前
前端算法新手如何刷算法?
前端·算法
喵个咪8 分钟前
开箱即用的 GoWind Admin|风行,企业级前后端一体中后台框架:用 JavaScript/Lua 解锁动态业务扩展能力
javascript·go·lua
BD_Marathon21 分钟前
Vue3_插值表达式
javascript
梦想是准点下班21 分钟前
【vue3】 + 【vite】 + 【vite-plugin-obfuscator】混淆打包 => 放弃了,样式会丢
前端·vue.js
前端达人22 分钟前
原生JavaScript vs 前端框架,2026年该怎么选?
开发语言·前端·javascript·前端框架·ecmascript
漫天黄叶远飞23 分钟前
React 组件通讯全攻略:拒绝 "Props" 焦虑,掌握数据流动的艺术
前端·react.js·前端框架
梦想是准点下班23 分钟前
【vue3】 + 【vite】 + 【rollup-plugin-obfuscator】混淆打包 => 打包报错
前端·vue.js
恋猫de小郭24 分钟前
Flutter UI 设计库解耦重构进度,官方解答未来如何适配
android·前端·flutter
星_离28 分钟前
高德地图-物流路线
前端·vue.js
细心细心再细心28 分钟前
Lexical 富文本编辑器组件详解
前端