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
相关推荐
一字白首10 分钟前
小程序组件化进阶:从复用到通信的完整指南DAY04
前端·小程序·apache
读忆11 分钟前
你是否用过Tailwind CSS?你是在什么情况下使用的呢?
前端·css·经验分享·笔记·taiiwindcss
阿珊和她的猫15 分钟前
探秘小程序:为何拿不到 DOM 相关 API
前端·小程序
弓.长.17 分钟前
ReactNative for OpenHarmony项目鸿蒙化三方库:@react-native-picker
react native·react.js·harmonyos
FlyWIHTSKY27 分钟前
Vue 3 onMounted 中控制同步与异步执行策略
前端·javascript·vue.js
弓.长.29 分钟前
ReactNative for OpenHarmony项目鸿蒙化三方库:react-native-button — 自定义按钮组件
react native·react.js·harmonyos
蜗牛攻城狮31 分钟前
【Vue3实战】El-Table实现“超过3行省略,悬停显示全文”的完美方案(附性能优化)
前端·vue.js·性能优化·element-plus
孙12~32 分钟前
前端vue3+vite,后端SpringBoot+MySQL
前端·html·学习方法
隔壁小邓33 分钟前
vue的组件化的理解之单独拆分的组件&组件的封装
前端·javascript·vue.js
困惑阿三35 分钟前
全栈部署排雷手册:从 405 报错到飞书推送成功
服务器·前端·后端·nginx·阿里云·node.js·飞书