前端生成拓扑图

应用npm库:@antv/x6

地址:https://x6.antv.antgroup.com/examples

支持自定义连接线的样式,支持自定义节点

1.注册节点样式

import { register } from '@antv/x6-vue-shape';

  register({

    shape: 'large-item',

    width: 100,

    height: 130,

    component: phoneLargeItem,

    ports: getPorts(100, 130),

  });

phoneLargeItem为引入的vue文件,可自定义样式,引入后作为拓扑图的节点

 2.生成图

const graph = new Graph({

      container: document.getElementById('g-container_' + taskId) as HTMLElement,

      autoResize: true,

      interacting: {

        nodeMovable: false,

        edgeMovable: true,

      },

    });

    const box = document.querySelector('#g-container_' + taskId);

    const boxRect = box?.getBoundingClientRect();

    //加入节点

    graph.addNode(

      getNodePorps({

        x: 50,

        y:  65,

        shape: 'large-item',

        id: 'cell',

        data: { id: 1 },//这个data可以被vue界面引入

      }),

    );

vue界面获取数据

  const node = getNode();

  const { data } = node;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值