React19通用ECharts組件的使用示例
好,我給你做一個(gè) React 19 通用 ECharts 組件,
支持餅圖 / 折線圖 / 柱狀圖,colors 可選,不傳也能顯示,防止重復(fù)渲染。
1.src/services/echarts.ts
注冊所有需要的圖表類型和組件(不用再分開寫折線/餅圖/柱狀圖)
// src/services/echarts.ts
import * as echarts from 'echarts/core';
import {
TitleComponent,
TooltipComponent,
GridComponent,
LegendComponent,
ToolboxComponent
} from 'echarts/components';
import { LineChart, PieChart, BarChart } from 'echarts/charts';
import { CanvasRenderer } from 'echarts/renderers';
// 按需注冊組件
echarts.use([
TitleComponent,
TooltipComponent,
GridComponent,
LegendComponent,
ToolboxComponent,
LineChart,
PieChart,
BarChart,
CanvasRenderer
]);
export default echarts;
2.src/components/EChartsBase.tsx
一個(gè)通用的 React 19 ECharts 組件
// src/components/EChartsBase.tsx
import React, { useRef, useEffect } from 'react';
import echarts from '@/services/echarts';
interface EChartsBaseProps {
option: echarts.EChartsOption;
width?: string;
height?: string;
}
const EChartsBase: React.FC<EChartsBaseProps> = ({
option,
width = '100%',
height = '400px'
}) => {
const chartRef = useRef<HTMLDivElement | null>(null);
const chartInstance = useRef<echarts.EChartsType | null>(null);
useEffect(() => {
if (chartRef.current) {
// 如果已有實(shí)例,先銷毀,防止 React 19 重復(fù)渲染
if (chartInstance.current) {
chartInstance.current.dispose();
}
chartInstance.current = echarts.init(chartRef.current);
chartInstance.current.setOption(option);
}
// 監(jiān)聽窗口大小變化
const handleResize = () => {
chartInstance.current?.resize();
};
window.addEventListener('resize', handleResize);
return () => {
chartInstance.current?.dispose();
window.removeEventListener('resize', handleResize);
};
}, [option]);
return <div ref={chartRef} style={{ width, height }} />;
};
export default EChartsBase;
3. 使用示例(不傳colors也能顯示)
// src/pages/DemoCharts.tsx
import React from 'react';
import EChartsBase from '@/components/EChartsBase';
export default function DemoCharts() {
const pieOption = {
title: { text: '示例餅圖', left: 'center' },
tooltip: { trigger: 'item' },
legend: { bottom: 0 },
series: [
{
name: '訪問來源',
type: 'pie',
radius: '50%',
data: [
{ value: 1048, name: '搜索引擎' },
{ value: 735, name: '直接訪問' },
{ value: 580, name: '郵件營銷' }
]
}
]
};
const lineOption = {
title: { text: '示例折線圖' },
tooltip: { trigger: 'axis' },
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', smooth: true }
]
};
const barOption = {
title: { text: '示例柱狀圖' },
tooltip: {},
xAxis: { type: 'category', data: ['蘋果', '香蕉', '橘子', '梨子'] },
yAxis: { type: 'value' },
series: [
{ data: [5, 20, 36, 10], type: 'bar' }
]
};
return (
<div style={{ padding: 20 }}>
<EChartsBase option={pieOption} height="300px" />
<EChartsBase option={lineOption} height="300px" />
<EChartsBase option={barOption} height="300px" />
</div>
);
}
? 特點(diǎn):
- React 19 兼容
- 餅圖 / 折線圖 / 柱狀圖通用
colors可選,不傳也正常顯示- 自動(dòng)銷毀實(shí)例,避免 React 19 重復(fù)渲染導(dǎo)致的圖表不顯示
- 自動(dòng)響應(yīng)窗口大小變化
到此這篇關(guān)于React19通用ECharts組件的使用示例的文章就介紹到這了,更多相關(guān)React通用ECharts內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用useImperativeHandle時(shí)父組件第一次沒拿到子組件的問題
這篇文章主要介紹了使用useImperativeHandle時(shí)父組件第一次沒拿到子組件的問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
React 組件中的state和setState()你知道多少
這篇文章主要為大家詳細(xì)介紹了React組件中的state和setState(),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
通過React實(shí)現(xiàn)頁面的無限滾動(dòng)效果
今天我們來聊聊無限滾動(dòng)這個(gè)現(xiàn)代Web開發(fā)中不可或缺的技術(shù),無論你是刷微博、逛知乎還是看腳本,無限滾動(dòng)都已經(jīng)滲透到我們?nèi)粘5臑g覽體驗(yàn)中,那么,如何優(yōu)雅地實(shí)現(xiàn)它呢?讓我們一起來探索吧,感興趣的小伙伴跟著小編一起來看看吧2025-09-09
React Agent 自定義實(shí)現(xiàn)代碼
在使用langchain的ReactAgent遇到問題后,作者嘗試自定義ReactAgent實(shí)現(xiàn),通過詳細(xì)分析langchain中的agent功能和問題,結(jié)合React思想,作者設(shè)計(jì)了新的agent邏輯并在GitHub上分享了代碼,新的ReactAgent通過改進(jìn)prompt和工具調(diào)用邏輯,提升了任務(wù)執(zhí)行的效果和穩(wěn)定性2024-10-10
React模仿網(wǎng)易云音樂實(shí)現(xiàn)一個(gè)音樂項(xiàng)目詳解流程
這篇文章主要介紹了React模仿網(wǎng)易云音樂實(shí)現(xiàn)一個(gè)音樂項(xiàng)目的詳細(xì)流程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
瀏覽器中視頻播放器實(shí)現(xiàn)的基本思路與代碼
這篇文章主要給大家介紹了關(guān)于瀏覽器中視頻播放器實(shí)現(xiàn)的基本思路與代碼,并且詳細(xì)總結(jié)了瀏覽器中的音視頻知識(shí),對(duì)大家的理解和學(xué)習(xí)非常有幫助,需要的朋友可以參考下2021-08-08

