在 React 中如何使用 Echarts

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


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

复制代码
npm install echarts

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

js 复制代码
import * as echarts from "echarts";

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

js 复制代码
     const chartRef = useRef<any>(null);

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

html 复制代码
    <>
      <div ref={chartRef} style={{ width: "500px", height: "350px" }}></div>
    </>

属性值

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

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

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

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

结果展示:

完整代码:

js 复制代码
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;
相关推荐
代码搬运媛7 小时前
Jest 测试框架详解与实现指南
前端
counterxing8 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq8 小时前
windows下nginx的安装
linux·服务器·前端
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜9 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108089 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen11 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm11 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy11 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao12 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端