当前位置: 首页 > article >正文

AntV X6使用Vue组件作为渲染节点

1.使用依赖

npm install @antv/x6 --save
npm install @antv/x6-vue-shape --save

下述代码使用Vue2技术栈,若使用Vue3则直接参考「AntV」X6 自定义vue节点(vue3) https://www.yuque.com/sxd_panda/antv/vue-node

2.节点组件

要点:

  • 使用inject注入AntV X6父组件中的依赖 getNode
  • 使用this.getNode()可以获取/监听,父组件在节点上配置的数据。
<!-- branch.vue -->
<template>
  <div>
      {{ name }}
  </div>
</template>
<script>
export default {
  inject: ["getNode"],
  data() {
    return {
      name: '',
    }
  },
  mounted() {
    const node = this.getNode();
    this.name = node.data.name;
    
    // 监听数据
    node.on('change:data',({current})=>{
    	console.log("监听父组件改变的数据",current)
    })
  }
}
</script>

3.父组件(使用节点渲染)

<template>
  <div>
    <div id="container" />
  </div>
</template>
<script>
// 引入 AntV X6 库
import { Graph } from '@antv/x6'
import { register } from '@antv/x6-vue-shape'

// 引入2中的子组件
import branch from './branch.vue'
// 制作组件节点
register({
  shape: 'branch-node',
  width: 100,
  height: 100,
  component: branch,
})
export default {
	mounted() {
    this.initGraph()
 	 },
	methods: {
		initGraph() {
			const width = window.innerWidth
	     	const height = window.innerHeight
			// 初始化 Graph 对象
	     	const graph = new Graph({
	        container: document.getElementById('container'), // 容器元素
	        width: width, // 设置宽度为屏幕宽度
	        height: height, // 设置高度为屏幕高度
	        interacting: {
	          nodeMovable: false, // 可拖拽节点
	          edgeMovable: false // 可拖拽边
	        },
	        connecting: {
	          connectionPoint: 'anchor'// 连接中心锚点
	        }
	      })
	      // 创建组件节点
	      const branchNode = graph.addNode({
	        x: 950,
	        y: 240,
	        shape: 'branch-node',
	        data: {
	          name: '组件节点名称'
	        },
	      })
		}
  }
}
</script>

Vue3方法参考:「AntV」X6 自定义vue节点(vue3) https://www.yuque.com/sxd_panda/antv/vue-node

参考地址

1.AntV X6结合Vue组件渲染节点,并与节点组件进行双向的数据交互.
2.Ant X6指南踩坑指南.


http://www.kler.cn/a/576692.html

相关文章:

  • Qt信号与槽机制实现原理
  • PHP之连接Mysql
  • Aruco 库详解:计算机视觉中的高效标记检测工具
  • fastjson漏洞
  • 更强的蛋白质突变效应预测!一键推理 DePLM 去噪蛋白质语言模型
  • MySQL DDL数据定义语句
  • Qt 实现抽屉效果实例
  • 用python做一个简单的可以调用手机摄像头进行车牌识别的H5页面
  • 数据中心精密配电监控:安科瑞精密配电监控解决方案破解高能耗与低效率困局
  • 联核科技AGV无人叉车的应用场景有哪些?
  • STM32 ADC模数转换
  • HTML:Web 开发的基石
  • AGI 之 【Dify】 之 使用 Docker 在 Windows 端本地部署 Dify 大语言模型(LLM)应用开发平台
  • 基于 Docker 的跨平台镜像构建与增量更新实战指南
  • 网络安全 信息安全 计算机系统安全
  • AI Agent 分类详解:从反射 Agent 到学习型 Agent 的演进
  • 企业大模型需求全景图:SFT、RAG与RL的协同与博弈
  • Golang的微服务服务发现机制
  • Vue 3 整合 WangEditor 富文本编辑器:从基础到高级实践
  • linux-git