React 中使用 Echarts

Echarts 一个基于 JavaScript 的开源可视化图表库


1、如果要在你的项目中使用 Echarts , 实现先安装对应的包,从 npm 获取

npm install echarts

2、安装完成之后再文件内引入

import * as echarts from "echarts";

3、声明一个 ref 给展示图标的元素,声明属性值

     const chartRef = useRef<any>(null);

注意:展示图标的元素一定要加宽高,否则看不到图表的

    <>
      <div ref={chartRef} style={{ width: "500px", height: "350px" }}></div>
    </>

属性值

const optionData = {
    title: {
      text: "ECharts 入门示例",
    },
    tooltip: {},
    xAxis: {
      data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],
    },
    yAxis: {},
    series: [
      {
        name: "销量",
        type: "bar",
        data: [5, 20, 36, 10, 10, 20],
      },
    ],
  };

4、使用,在挂载阶段渲染,关闭页面后销毁,以免内存泄漏

useEffect(() => {
    // 挂载阶段
    const chart = echarts.init(chartRef.current);
    chart.setOption(optionData);

    // 销毁
    return () => {
      chart.dispose();
    };
  }, []);

结果展示:

在这里插入图片描述

完整代码:

import * as echarts from "echarts";
import { useEffect, useRef } from "react";
const EchartsPage = () => {
  const chartRef = useRef<any>(null);
  const optionData = {
    title: {
      text: "ECharts 入门示例",
    },
    tooltip: {},
    xAxis: {
      data: ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"],
    },
    yAxis: {},
    series: [
      {
        name: "销量",
        type: "bar",
        data: [5, 20, 36, 10, 10, 20],
      },
    ],
  };

  useEffect(() => {
    // 挂载阶段
    const chart = echarts.init(chartRef.current);
    chart.setOption(optionData);

    // 销毁
    return () => {
      chart.dispose();
    };
  }, []);
  return (
    <>
      <div ref={chartRef} style={{ width: "500px", height: "350px" }}></div>
    </>
  );
};

export default EchartsPage;

<think>好的,我现在需要在React项目中集成ECharts来实现数据可视化。首先,我应该了解如何安装ECharts。根据引用[1]和[3],用户提到在React项目中引入ECharts,所以可能需要通过npm安装。命令应该是npm install echarts --save,对吗? 接下来,安装完成后,如何在React组件中正确使用呢?可能需要导入ECharts库,然后在组件挂载后初始化图表。引用[3]提到项目中使用的是React + TS + Vite,所以可能需要考虑类型定义。是否需要安装@types/echarts?不过ECharts本身可能已经包含类型,所以可能不需要额外安装。 然后,创建一个容器元素,比如一个div,并设置其宽度和高度,否则图表可能无法显示。在useEffect钩子中进行初始化,确保DOM已经渲染。记得在卸载时销毁图表实例,避免内存泄漏。引用中的示例代码可能展示了这个过程,比如使用useRef来保持实例引用。 另外,引用[2]提到了datav框架,但用户的问题是关于ECharts的,所以暂时可以忽略datav。不过,如果需要制作数据大屏,结合datav可能更好,但当前问题不涉及这个。 关于配置项,ECharts的选项比较复杂,用户可能需要根据数据类型选择合适的图表类型,比如折线图、柱状图等。如何动态更新数据呢?可能需要监听props的变化,然后使用setOption更新图表。 还有响应式布局的问题,当窗口大小变化时,图表应该自适应调整。可以通过监听resize事件,并调用ECharts实例的resize方法来实现。 总结步骤应该是:安装ECharts,在组件中引入并初始化,配置选项,处理更新和销毁。需要确保代码符合React的生命周期,避免副作用。同时,参考给出的引用中的示例,可能需要使用useRef来保存图表实例,并在useEffect中处理初始化和清理。</think>### 如何在 React使用 ECharts 实现数据可视化 #### 1. 安装 ECharts 通过 npm 安装 ECharts 核心库: ```bash npm install echarts --save ``` 若需兼容 React 生态,可添加相关类型定义(TS 项目): ```bash npm install @types/echarts --save-dev # 非必须,ECharts 5+ 已内置类型 ``` #### 2. 基础集成步骤 **步骤 1:创建图表容器** 在组件中定义一个具有固定尺寸的容器: ```tsx <div id="chart-container" style={{ width: '600px', height: '400px' }} /> ``` **步骤 2:初始化图表** 在 React 组件中使用 `useEffect` 初始化 ECharts: ```tsx import React, { useEffect, useRef } from 'react'; import * as echarts from 'echarts'; const ChartComponent = () => { const chartRef = useRef<HTMLDivElement>(null); const chartInstance = useRef<echarts.ECharts>(); useEffect(() => { if (chartRef.current) { // 初始化图表实例 chartInstance.current = echarts.init(chartRef.current); // 配置图表选项 const option = { xAxis: { type: 'category', data: ['A', 'B', 'C'] }, yAxis: { type: 'value' }, series: [{ type: 'bar', data: [10, 20, 30] }] }; chartInstance.current.setOption(option); // 窗口变化时自适应 const resizeHandler = () => chartInstance.current?.resize(); window.addEventListener('resize', resizeHandler); // 清理函数 return () => { window.removeEventListener('resize', resizeHandler); chartInstance.current?.dispose(); }; } }, []); return <div ref={chartRef} style={{ width: '100%', height: '100%' }} />; }; ``` #### 3. 动态数据更新 通过监听 props 或 state 变化更新图表: ```tsx useEffect(() => { if (chartInstance.current && data) { const newOption = { ...baseOption, series: [{ data }] }; chartInstance.current.setOption(newOption); } }, [data]); // data 变化时触发更新 ``` #### 4. 高级功能 - **按需引入模块**:减少打包体积: ```ts import { BarChart, LineChart } from 'echarts/charts'; import { TooltipComponent, GridComponent } from 'echarts/components'; echarts.use([BarChart, LineChart, TooltipComponent, GridComponent]); ``` - **主题定制**:通过 `echarts.registerTheme()` 应用自定义主题[^3]。 - **交互事件**:通过 `chartInstance.current.on('click', callback)` 绑定事件。 #### 5. 性能优化 - 使用 `resizeObserver` 替代 `window.resize` 监听容器尺寸变化更精准。 - 复杂图表开启 `animation: false` 或 `throttle` 渲染避免卡顿。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值