前言:

        react+echarts实现图表展示。

1、直接用echarts的插件来实现

1)安装

npm install echarts

2)使用

1、useEffect是react中集合onload/watch监听等方法与一体的hook函数,他的第二个参数是空数组,则等同于onload,只执行一次,如果给他传入有内容的数据,则等同于watch,当参数发生改变就会实时调用数据。

2、useRef 是react中类似ref的 hook 函数,实现元素的获取

案例源码:
// 引入依赖插件
import React, { useEffect, useRef } from 'react';
import echarts from 'echarts';// 输入js逻辑
const EchartsDemo = () => {// useRef = 我们的ref方法const chartRef = useRef(null);// 第二个参数为空的时候,等同于onload方法useEffect(() => {const chartDom = chartRef.current;// 传统的echarts.init+dom元素方法const myChart = echarts.init(chartDom);const option = {title: {text: '示例图表',},tooltip: {trigger: 'axis',},xAxis: {type: 'category',data: ['苹果', '香蕉', '橙子', '葡萄', '西瓜'],},yAxis: {type: 'value',},series: [{name: '销量',type: 'bar',data: [100, 200, 150, 80, 90],},],};myChart.setOption(option);return () => {myChart.dispose();};}, []);// 这里因为传入[],所以只执行一次return (<div className="echarts-container"><div ref={chartRef} style={{ width: '100%', height: '400px' }} /></div>);
};export default EchartsDemo;

1、使用useState 这个react的hook来实现变量的双休绑定,注意他的用法是两个参数,第一个是定义的变量,第二个是修改这个变量的方法,比如:

const [echartData, setData] = useState([12, 20, 15, 18, 18])

意思就是,定义了一个变量echartData ,默认值是 【12, 20, 15, 18, 18】

然后调用setData这个方法,就可以修改echartData变量的内容

2、将useEffect 的hook的第二个参数设置成echartData,那么echartData发生改变的时候,useEffect的逻辑会再次触发,实现数据监听改变逻辑

源码2
​
import React, { useEffect, useRef, useState } from 'react';
import echarts from 'echarts';const EchartsDemo = () => {const chartRef = useRef(null);// 使用useState来修改数据const [echartData, setData] = useState([12, 20, 15, 18, 18]);useEffect(() => {const chartDom = chartRef.current;const myChart = echarts.init(chartDom);const option = {title: {text: '示例图表',},tooltip: {trigger: 'axis',},xAxis: {type: 'category',data: ['苹果', '香蕉', '橙子', '葡萄', '西瓜'],},yAxis: {type: 'value',},series: [{name: '销量',type: 'bar',data: data,},],};myChart.setOption(option);return () => {myChart.dispose();};}, [echartData]);// 点击更新数据方法const updateData = () => {   // 可以在这里异步获取数据然后直接更改变量就行了let arr = [100, 200, 150, 80, 90]setData(arr);};return (<div className="echarts-container"><div ref={chartRef} style={{ width: '100%', height: '400px' }} /><button onClick={updateData}>更新数据</button></div>);
};export default EchartsDemo;​

2、使用 echarts-for-react 插件来更好的实现

1)安装

npm install echarts echarts-for-react

2)使用

1、memo: 是一个高阶组件(Higher-Order Component,HOC),用于优化函数组件的性能。它的作用是阻止组件在父组件重新渲染时不必要的重新渲染,除非组件的 props 发生变化

2、useEffect就是onload+watch的hook函数

3、useState是定义变量,修改变量的hook函数

和第一种方法区别:

使用了ReactEChartsCore这个标签,还有像提示框,弹框等都可以单独引入,TooltipComponent, GridComponent 等等,还有canvas等

ReactEChartsCore
line/index.jsx源码:
import React, { memo, useEffect, useState } from "react";
import ReactEChartsCore from "echarts-for-react/lib/core";
import * as echarts from "echarts/core";
import { BarChart } from "echarts/charts";
import { TooltipComponent, GridComponent } from "echarts/components";
import { CanvasRenderer } from "echarts/renderers";echarts.use([TooltipComponent, GridComponent, BarChart, CanvasRenderer]);function Line({ theme = "light", style = {}, option = {} }) {const [echartRef, setRef] = useState<ReactEChartsCore | null>(null);useEffect(() => {if (echartRef) {echartRef.getEchartsInstance().setOption(option);}}, [option]);return (<ReactEChartsCorekey="echart"ref={setRef}echarts={echarts}option={option}theme={theme}style={style}notMerge={true}lazyUpdate={true}/>);
}export default memo(Line, (prev, next) => prev.option === next.option);
封装一个echarts/index.jsx来管理所有的图表,里面放个antd的loading效果
import loadable from "@loadable/component";
import { Spin } from "antd";const loaddingCom = (<Spinstyle={{display: "flex",alignItems: "center",justifyContent: "center",minHeight: 20,fontSize: 14,}}tip="组件加载中...."/>
);const Line = loadable(() => import("./line"), { fallback: loaddingCom });
export { Line};
界面中调用
// 引入echarts
import { Line as LineEchart } from "@/components/echarts";const visitorOpt = {xAxis: {type: 'category', // 横轴类型data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] // 横轴数据},yAxis: {type: 'value' // 纵轴类型},series: [{data: [150, 230, 224, 218, 135, 147, 260], // 数据type: 'line' // 图表类型,折线图}]
}
const echartStyle = {height: 50,
}// 具体使用
<LineEchart option={visitorOpt} style={echartStyle} />

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/95311.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/95311.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/95311.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Apache 服务器基础配置与虚拟主机部署

Apache 服务器基础配置与虚拟主机部署 Apache 的核心定位与作用&#xff1a; Apache 的核心功能是处理 HTTP 请求并提供 Web 资源&#xff0c;是客户端&#xff08;如浏览器&#xff09;与 Web 服务器之间的 “中间人”&#xff1a; 接收客户端通过 HTTP/HTTPS 协议发送的请求…

线性代数 · 矩阵 | 最小多项式

注&#xff1a;本文为 “矩阵 | 最小多项式” 相关合辑。 略作重排&#xff0c;如有内容异常&#xff0c;请看原文。 最小多项式 橘子蜂蜜 于 2019-05-22 22:48:25 发布 根据哈密顿 - 凯莱&#xff08;Hamilton - Cayley&#xff09;定理&#xff0c;任给数域 PPP 上的一个 …

docter的使用、vscode(cursor)和docker的连接,详细分析说明

目录 一、基本命令 二、用案例来学习使用方法 &#x1f680; Pull Python 3.11 镜像并创建命名容器 &#x1f4cb; 其他有用命令 在容器中安装依赖 三、直接在镜像中安装依赖&#xff08;创建自己定制的镜像&#xff09; 四、在 cursor 中选用容器作为编译器 五、对于整…

如何使用AI大语言模型解决生活中的实际小事情?

我们总以为AI是遥不可及的未来科技&#xff0c;却忽视了它早已成为生活中最实用的“隐形助手”。在信息爆炸的今天&#xff0c;我们每天被无数生活琐事包围&#xff1a;一封专业邮件反复修改措辞、孩子突如其来的数学难题、冰箱里仅剩的食材如何搭配、旅行行程的繁琐规划……这…

关于微信小程序的笔记

1.需要获取demo素材图片方法&#xff08;2,3&#xff09;2.使用逆向工具进行解包没有安装node的需要安装一下安装npm i -g wedecode0.8.0-beta.3获取小程序文件存放路径/Users/lin/Library/Containers/com.tencent.xinWeChat/Data/.wxapplet/packages/wx060ecb4f74eac0da根据具…

课堂笔记:吴恩达的AI课(AI FOR EVERYONE)-W2 AI项目工作流程

课堂笔记&#xff1a;吴恩达的AI课&#xff08;AI FOR EVERYONE&#xff09;-W2 AI项目工作流程 一、如何开始一个AI项目&#xff1f; 1、建设项目工作流程 2、选择合适的AI项目 3、为这个项目收集数据和组织团队二、AI项目的工作流程 &#xff08;1&#xff09;机器学习项目的…

逐际动力开源运控 tron1-rl-isaacgym 解读与改进

文章目录概览基础框架解读线速度估计观测结构仿真实验点足式步态设计步态相位与接触状态建模步态接触奖励动作延迟我的改进Point-goal Locomotion观测修改奖励修改预训练地形编码器Sliced Wasserstein AutoEncoder模型训练与结果参考材料概览 这篇博客记录了我参加逐际动力创学…

人工智能-python-机器学习-线性回归与梯度下降:理论与实践

文章目录线性回归与梯度下降&#xff1a;理论与实践1. 引言2. 回归分析2.1 什么是回归&#xff1f;2.2 线性回归2.3 损失函数2.4 多参数回归3. 参数求解&#xff1a;最小二乘法3.1 最小二乘法 MSE3.2 最小二乘法的优缺点优点&#xff1a;缺点&#xff1a;4. 梯度下降4.1 梯度下…

前端,elment-plus组件:表格,分页,对话框,表单

Element Plus 核心特性组件体系&#xff1a;表单、表格、弹窗、导航等高频组件设计理念主题定制&#xff1a;Sass 变量覆盖与暗黑模式无缝切换国际化支持&#xff1a;多语言动态切换的实现机制TypeScript 支持&#xff1a;完整的类型定义与开发友好性快速上手指南安装与基础配置…

【LeetCode】6. Z 字形变换

文章目录6. Z 字形变换题目描述示例 1&#xff1a;示例 2&#xff1a;示例 3&#xff1a;提示&#xff1a;解题思路算法分析问题本质分析Z字形排列过程详解Z字形排列可视化方向控制策略数学规律法详解各种解法对比算法流程图边界情况处理时间复杂度分析空间复杂度分析关键优化点…

spring文件下载的方式

spring文件下载的方式方式一:通过ResponseEntity<Resource> 方式来下载方式二:通过ResponseEntity<StreamingResponseBody> 方式来下载方式三:通过Servlet原生下载方式四:通过ResponseEntity<byte[]> 方式来下载四种下载方式的对比1、核心特性对比2、典型场景…

写一个redis客户端软件,参考 Another Redis Desktop Manager 的设计风格。

一个基于 Electron 开发的现代化 Redis 桌面客户端&#xff0c;参考 Another Redis Desktop Manager 的设计风格。 github仓库地址 https://github.com/henkuoai/redis-man-pc

Web3: DeFi借贷的安全基石, 了解喂价与清算机制的原理与重要性

今天我们要聊一个DeFi世界里至关重要&#xff0c;但又时常被误解的话题&#xff1a;为什么DeFi协议需要定期更新喂价和执行清算&#xff1f; 如果大家参与过DeFi借贷&#xff0c;大家可能看到过“清算”这个词&#xff0c;甚至会有点谈虎色变。但实际上&#xff0c;清算和为其提…

「iOS」————响应者链与事件传递链

iOS学习响应者链和事件传递链传递链&#xff1a;hitTest:withEvent**pointInside:withEvent**响应链第一响应者和最佳响应者触摸事件&#xff08;UITouch&#xff09;UIGestureRecognizer&#xff08;手势识别器&#xff09;响应者链和事件传递链 iOS事件的主要由&#xff1a;…

修复图像、视频和3D场景的AI工具–Inpaint Anything

TL; DR&#xff1a;用户可以通过单击来选择图像中的任何对象。借助强大的视觉模型&#xff0c;例如SAM、LaMa和稳定扩散 (SD)&#xff0c;Inpaint Anything能够顺利地移除对象&#xff08;即Remove Anything&#xff09;。此外&#xff0c;在用户输入文本的提示下&#xff0c;I…

java -jar xxx.jar 提示xxx.jar中没有主清单属性报错解决方案

xxx.jar 中没有主清单属性 &#xff08;no main manifest attribute&#xff09;解决方案 java -jar xxx.jar 提示xxx.jar中没有主清单属性报错解决方案 这个错通常出现在你用 java -jar xxx.jar 启动&#xff0c;但 JAR 的 META-INF/MANIFEST.MF 里没有 Main-Class 条目&#…

Myqsl建立库表练习

目录 一、windows中选择一种方式安装Mysql8.0 二、新建产品库mydb6_product 1. 新建3张表如下&#xff1a; 1&#xff09;employees表 2&#xff09;orders表 3&#xff09;invoices表 三、新建员工库mydb8_worker&#xff0c;添加自定义表内容并插入数据 1. 新建库表 2. 插…

STM32 输入捕获,串口打印,定时器,中断综合运用

实验目的 使用定时器 2 通道 2 来捕获按键 2 按下时间&#xff0c;并通过串口打印。 计一个数的时间&#xff1a;1us&#xff0c;PSC71&#xff0c;ARR65535 下降沿捕获、输入通道 2 映射在 TI2 上、不分频、不滤波输入捕获原理定时器输入捕获实验配置步骤测量按键按下时长思路…

Nacos-2--Nacos1.x版本的通信原理

在Nacos 1.x版本中&#xff0c;客户端长轮询&#xff08;Long Polling&#xff09;和服务端UDP主动推送是两种不同的机制&#xff0c;分别用于配置管理和服务发现场景。它们的核心目标都是实现动态更新的实时感知&#xff0c;但实现方式、数据内容和适用场景完全不同。 1、长轮…

机器学习——09 聚类算法

1 聚类算法聚类算法&#xff1a; 是一种无监督学习算法&#xff0c;它不需要预先知道数据的类别信息&#xff0c;而是根据样本之间的相似性&#xff0c;将样本划分到不同的类别中&#xff1b;不同的相似度计算方法&#xff0c;会得到不同的聚类结果&#xff0c;常用的相似度计算…