当前位置: 首页 > news >正文

react,使用echarts过程

第一步:安装echarts

npm install echarts

第二步:创造echarts组件:

代码:

import React, { useEffect, useRef } from 'react'
import * as echarts from 'echarts';function Myecharts(props) {// 使用useRef钩子来存储图表容器的DOM元素引用。let box = useRef()// 在组件挂载后和props.option变化时执行的副作用函数。useEffect(() => {console.log(box.current)// 初始化Echarts实例。var myChart = echarts.init(box.current);console.log(props.option)// 根据props.option的存在与否,设置图表的配置选项。if(props.option!=null){myChart.setOption(props.option)}else{console.log("没有传过来")}}, [props.option]) // 仅当props.option变化时,重新执行副作用函数。// 设置图表容器的样式。不然撑不开const stylestr = {width: '100%',height:'100%'}// 返回图表的容器元素。return (<div ref={box} id='main' style={stylestr}></div>)
}export default Myecharts

第三步:在页面中使用当前组件,代码如下

/*** 首页组件。* * 该组件渲染一个包含图表的页面。图表使用Echarts库绘制,展示了不同渠道的访问量。* 它通过定义并使用Echarts的配置选项来定制图表的外观和行为。*/
import Myecharts from '../compoents/Myecharts'function About() {// 定义Echarts图表的配置选项let option = {tooltip: {trigger: 'axis'},legend: {icon: "circle",data: ['Email', 'Union Ads', 'Video Ads', 'Direct', 'Search Engine']},grid: {left: '3%',right: '4%',bottom: '3%',containLabel: true},xAxis: {type: 'category',boundaryGap: false,data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']},yAxis: {type: 'value'},series: [{name: 'Email',type: 'line',stack: 'Total',showSymbol: false,smooth: true,data: [120, 132, 101, 134, 90, 230, 210]},{name: 'Union Ads',type: 'line',stack: 'Total',showSymbol: false,smooth: true,data: [220, 182, 191, 234, 290, 330, 310]},{name: 'Video Ads',type: 'line',smooth: true,showSymbol: false,stack: 'Total',data: [150, 232, 201, 154, 190, 330, 410]},{name: 'Direct',type: 'line',smooth: true,showSymbol: false,stack: 'Total',data: [320, 332, 301, 334, 390, 330, 320]},{name: 'Search Engine',type: 'line',smooth: true,showSymbol: false,stack: 'Total',data: [820, 932, 901, 934, 1290, 1330, 1320]}]};//注意要有样式,不然撑不开const stystr = {width: '500px',height: '500px'}// 返回图表容器组件return (<div style={stystr}><Myecharts option={option}></Myecharts></div>)
}export default About

相关文章:

  • ShardingSphere解析:分布式数据库中间件的分片设计与事务管理实践
  • 【React】常用的状态管理库比对
  • 脑电震动音频震动信号模拟器设计资料:758-2路32bit DA 脑电震动音频信号模拟器
  • 2025pmx文件怎么打开blender
  • linux驱动开发(7)-互斥与同步
  • 力扣HOT100之终章:一些随笔
  • 【力扣 简单 C】21. 合并两个有序链表
  • Rabbitmq后台无法登录问题解决
  • android:foregroundServiceType详解
  • 力扣HOT100之技巧:169. 多数元素
  • 代码随想录算法训练营day2
  • 图像匹配算法 笔记2025
  • day53 神经网络调参指南
  • Packagerun:VSCode 扩展 快捷执行命令
  • ajax访问阿里云天气接口,获取7天天气
  • 相机Camera日志实例分析之三:相机Camx【视频光斑人像录制】单帧流程日志详解
  • JSON 与 AJAX
  • 安装配置以太链钱包工具
  • 解决 PyTorch 与 Python 3.12 的兼容性问题:`operator torchvision::nms does not exist` 深度解析
  • 台湾TEMI协会竞赛——2、足球机器人组装教学
  • 一个网站开发流程/seo网络推广招聘
  • 怎么做网站链接的快捷方式/南宁seo外包服务商
  • 郑州网站seo厂家/真正免费的网站建站平台推荐
  • 上海人才网最新招聘信息2022年/seo外链自动群发工具
  • 广扬建设集团网站/中国seo关键词优化工具
  • 网站友情链接怎么设置/百度网络营销推广