在 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;
相关推荐
凯子坚持 c25 分钟前
生产级 Rust Web 应用架构:使用 Axum 实现模块化设计与健壮的错误处理
前端·架构·rust
IT_陈寒31 分钟前
Python 3.12新特性实战:5个让你的代码效率翻倍的隐藏技巧!
前端·人工智能·后端
程序员小寒38 分钟前
前端高频面试题之Vuex篇
前端·javascript·面试
网硕互联的小客服1 小时前
如何解决 Linux 文件系统挂载失败的问题?
linux·服务器·前端·网络·chrome
程序员爱钓鱼2 小时前
Python 编程实战 · 实用工具与库 — Flask 路由与模板
前端·后端·python
合作小小程序员小小店5 小时前
web开发,在线%超市销售%管理系统,基于idea,html,jsp,java,ssh,sql server数据库。
java·前端·sqlserver·ssh·intellij-idea
不爱学英文的码字机器6 小时前
重塑 Web 性能:用 Rust 与 WASM 构建“零开销”图像处理器
前端·rust·wasm
浩星6 小时前
react的框架UmiJs(五米)
前端·javascript·react.js
子醉8 小时前
推荐一种适合前端开发使用的解决本地跨域问题的办法
前端
Niyy_8 小时前
前端一个工程构建多个项目,记录一次工程搭建
前端·javascript