【React】基于Echarts实现关系图(图谱&graph)

效果

在这里插入图片描述

环境

  • echarts: ^5.5.0
  • lodash: ^4.17.21
  • next: 14.1.3
  • react: ^18

目录

仅包含涉及到的文件

| - app
   |- page.tsx
| - components
    |- echarts
       |- graph
          |- echarts.ts
          |- index.tsx

实操

创建EchartsGraph组件

  • components/echarts/graph/index.tsx
"use client"

import react, {
   
   useEffect, useRef} from "react";
import EchartsContainer from "./echarts"

type Props = {
   
   
    nodes: object[],
    edges: object[],
    categories: object[]
}

const ChartBoxStyles:react.CSSProperties = {
   
   
    width: '100%',
    height: '100%'
}

const EchartsGraph = function (props: Props) {
   
   
    let echartsRef = useRef<HTMLDivElement>(null);

    useEffect(()=>{
   
   
        const chart = EchartsContainer(echartsRef.current);
        chart.setOption({
   
   
            legend: [
                {
   
   
                    data: props.categories.map(function (a:any) {
   
   
                        return a.name;
                    })
                }
            ],
            series: [
                {
   
   
                    nodes: props.nodes,
                    edges: props.edges,
                    categories: props.categories,
                }
            ]
        });
        // 绑定鼠标松开触发事件,用于固定节点
        chart.on('mouseup', function (params: any) {
   
   
            
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

转悠的陀螺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值