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

相关推荐
Martin -Tang16 分钟前
vite和webpack的区别
前端·webpack·node.js·vite
迷途小码农零零发17 分钟前
解锁微前端的优秀库
前端
王解1 小时前
webpack loader全解析,从入门到精通(10)
前端·webpack·node.js
老码沉思录1 小时前
写给初学者的React Native 全栈开发实战班
javascript·react native·react.js
我不当帕鲁谁当帕鲁1 小时前
arcgis for js实现FeatureLayer图层弹窗展示所有field字段
前端·javascript·arcgis
那一抹阳光多灿烂1 小时前
工程化实战内功修炼测试题
前端·javascript
放逐者-保持本心,方可放逐2 小时前
微信小程序=》基础=》常见问题=》性能总结
前端·微信小程序·小程序·前端框架
毋若成4 小时前
前端三大组件之CSS,三大选择器,游戏网页仿写
前端·css
红中马喽4 小时前
JS学习日记(webAPI—DOM)
开发语言·前端·javascript·笔记·vscode·学习
Black蜡笔小新5 小时前
网页直播/点播播放器EasyPlayer.js播放器OffscreenCanvas这个特性是否需要特殊的环境和硬件支持
前端·javascript·html