使用 React 定义节点
上一篇
自定义节点
下一篇
边总览
Loading...
在 G6 中,自定义节点通常需要操作 DOM 或 Canvas 元素,但借助 @antv/g6-extension-react
一方生态库,可以直接使用 React 组件作为节点内容,提升开发效率与可维护性。
✅ 推荐场景:
有关如何使用 Canvas 图形自定义节点的详细信息,请参阅 自定义节点 文档
✅ 推荐场景:
在开始之前,请确保您已经:
要使用 @antv/g6-extension-react
,请运行以下命令:
npm install @antv/g6-extension-react
通过扩展机制注册 React 节点类型:
import { ExtensionCategory, register } from '@antv/g6';import { ReactNode } from '@antv/g6-extension-react';register(ExtensionCategory.NODE, 'react-node', ReactNode);
register
方法需要三个参数:
ExtensionCategory.NODE
表示这是一个节点类型react-node
是我们给这个自定义节点起的名字,后续会在配置中使用@antv/g6-extension-react
导出的实现类定义一个简单的 React 组件作为节点的内容:
const MyReactNode = () => {return <div>node</div>;};
在图配置中使用自定义的 React 节点。通过在图配置中指定节点类型和样式,来使用自定义的 React 组件。
type
:指定节点类型为 react-node
(使用与注册时起的名字)style.component
:定义节点的 React 组件内容const graph = new Graph({node: {type: 'react-node',style: {component: () => <MyReactNode />,},},});graph.render();
在复杂图可视化场景中,节点需要动态响应交互状态。我们提供两种互补的状态管理方案:
G6 提供内置的交互状态管理状态,如 hover-activate
和 click-select
。可以通过节点数据中的 data.states
字段获取当前节点状态,并根据状态调整节点样式。
示例:在节点被 hover 时改变背景颜色。
import { ExtensionCategory, register, Graph } from '@antv/g6';import { ReactNode } from '@antv/g6-extension-react';register(ExtensionCategory.NODE, 'react-node', ReactNode);const StatefulNode = ({ data }) => {const isActive = data.states?.includes('active');return (<divstyle={{width: 100,padding: 5,border: '1px solid #eee',boxShadow: isActive ? '0 0 8px rgba(24,144,255,0.8)' : 'none',transform: `scale(${isActive ? 1.05 : 1})`,}}>{data.data.label}</div>);};const graph = new Graph({data: {nodes: [{ id: 'node1', style: { x: 100, y: 200 }, data: { label: 'node1' } },{ id: 'node2', style: { x: 300, y: 200 }, data: { label: 'node2' } },],},node: {type: 'react-node',style: {component: (data) => <StatefulNode data={data} />,},},behaviors: ['hover-activate'],});graph.render();
当需要管理业务相关状态(如审批状态、风险等级)时,可通过扩展节点数据实现:
示例:通过 data 添加 selected
变量,实现节点选中和取消选中的样式变化。
import { ExtensionCategory, register, Graph } from '@antv/g6';import { ReactNode } from '@antv/g6-extension-react';register(ExtensionCategory.NODE, 'react-node', ReactNode);const MyReactNode = ({ data, graph }) => {const handleClick = () => {graph.updateNodeData([{ id: data.id, data: { selected: !data.data.selected } }]);graph.draw();};return (<divstyle={{width: 200,padding: 10,border: '1px solid red',borderColor: data.data.selected ? 'orange' : '#ddd', // 根据选中状态设置边框颜色cursor: 'pointer', // 添加鼠标指针样式}}onClick={handleClick}>Node</div>);};const graph = new Graph({data: {nodes: [{id: 'node1',style: { x: 100, y: 100 },data: { selected: true },},],},node: {type: 'react-node',style: {component: (data) => <MyReactNode data={data} graph={graph} />,},},});graph.render();
实现节点与图实例的双向通信,使节点和图实例可以相互更新。
示例:通过自定义节点操作图数据,并重新渲染图形。
const IDCardNode = ({ id, selected, graph }) => {const handleSelect = () => {graph.updateNodeData([{ id, data: { selected: true } }]);graph.draw();};return <Select onChange={handleSelect} style={{ background: selected ? 'orange' : '#eee' }} />;};const graph = new Graph({node: {type: 'react-node',style: {component: ({ id, data }) => <IDCardNode id={id} selected={data.selected} graph={graph} />,},},});