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;
相关推荐
ofoxcoding21 分钟前
MiniMax M3 实测手记:踩完坑之后,我总结了报错处理和省 token 的几个办法
java·前端·人工智能·ai
YG亲测源码屋27 分钟前
html表白代码大全可复制免费 html表白网页制作源码
前端·html
夜雪闻竹31 分钟前
React Query + REST API 最佳实践
前端·react.js·前端框架
段ヤシ.32 分钟前
回顾Java知识点,面试题汇总Day12:tomcat、 Java Web(持续更新)
java·前端·tomcat·java web
JAVA学习通33 分钟前
从 Bean 到微服务:一张图吃透 Spring 全家桶底层原理
java·前端·spring
古韵35 分钟前
前端请求库的下一个进化方向:从 Promise 到策略化
前端
独特的螺狮粉36 分钟前
蛋鸡养护周期管理系统 - 鸿蒙PC Electron框架完整实现指南
前端·javascript·华为·electron·前端框架·开源·鸿蒙
忧郁的蛋~41 分钟前
ASP.NET Core Web API 完全指南:请求管道、认证、错误处理到生产部署
前端·后端·asp.net·.net
我穿棉裤了1 小时前
解决el-form表单校验时显示的红色星号与文字对齐的问题
前端·javascript·vue.js
copyer_xyf1 小时前
Python 类全面总结
前端·后端·python