react+typescript中使用echarts的實(shí)現(xiàn)步驟
npm install echarts --save
按需加載Echarts demo
import * as echarts from 'echarts/core'
import {
BarChart,
// 系列類型的定義后綴都為 SeriesOption
LineChart,
} from 'echarts/charts'
import {
TitleComponent,
// 組件類型的定義后綴都為 ComponentOption
TooltipComponent,
GridComponent,
// 數(shù)據(jù)集組件
DatasetComponent,
// 內(nèi)置數(shù)據(jù)轉(zhuǎn)換器組件 (filter, sort)
TransformComponent,
} from 'echarts/components'
import { LabelLayout, UniversalTransition } from 'echarts/features'
import { CanvasRenderer } from 'echarts/renderers'
import { useEffect, useRef } from 'react'
// 注冊(cè)必須的組件
echarts.use([
TitleComponent,
TooltipComponent,
GridComponent,
DatasetComponent,
TransformComponent,
BarChart,
LabelLayout,
UniversalTransition,
CanvasRenderer,
LineChart,
])
const ECharts: React.FC = () => {
// 1. get DOM
const chartRef = useRef(null)
useEffect(() => {
// 2. 實(shí)例化表格對(duì)象
const chart = echarts.init(chartRef.current as unknown as HTMLDivElement, undefined, {
width: 1000,
height: 500,
})
// 3. 定義數(shù)據(jù)
const option = {
title: {
text: '測(cè)試圖表',
},
xAxis: {
type: 'category',
data: ['1-1', '1-2', '1-3', '1-5', '1-6', '1-7', '1-8', '1-9'],
},
yAxis: {
type: 'value',
},
series: [
{
data: [140, 110, 100, 90, 70, 30, 10, 0],
type: 'line',
},
],
}
// 4. 調(diào)用表格數(shù)據(jù)
chart.setOption(option)
}, [])
return <div className="charts" ref={chartRef} />
}
export default ECharts
錯(cuò)誤記錄
實(shí)例化Echarts的時(shí)候出現(xiàn):“類型“null”的參數(shù)不能賦給類型“HTMLElement”的參數(shù)”錯(cuò)誤,是typescript類型檢查引起的,因此需要對(duì)該chartRef.current定義類型,可以定義成any,這里用的是typescript的雙重?cái)嘌?/a>去定義的類型。
發(fā)生錯(cuò)誤的代碼

修改后的代碼

注意:
類型斷言只能夠「欺騙」TypeScript 編譯器,無(wú)法避免運(yùn)行時(shí)的錯(cuò)誤,反而濫用類型斷言可能會(huì)導(dǎo)致運(yùn)行時(shí)錯(cuò)誤 類型斷言只會(huì)影響
TypeScript 編譯時(shí)的類型,類型斷言語(yǔ)句在編譯結(jié)果中會(huì)被刪除,所以它不是類型轉(zhuǎn)換,不會(huì)真的影響到變量的類型。
將圖表改為自適應(yīng)容器大小 – .resize()
echarts中提供了resize函數(shù)能夠自動(dòng)改變圖表的大小,但是需要使用window.onresize去監(jiān)聽(tīng)窗口的變化,只要窗口尺寸變化了就調(diào)用resize方法,并且圖表的寬度和高度要分別設(shè)置成百分比和vh單位,否則resize會(huì)失效。
基于上面的demo實(shí)現(xiàn):
多復(fù)制一個(gè)表格數(shù)據(jù)之后在調(diào)用表格數(shù)據(jù)后面加window.resize函數(shù),有多少個(gè)表就繼續(xù)往后面加多少個(gè)resize。
// 4. 調(diào)用表格數(shù)據(jù)
chart.setOption(option)
chart2.setOption(option2)
// 5. 將圖表變?yōu)樽赃m應(yīng)
window.onresize = () => {
chart.resize()
chart2.resize()
}
到此這篇關(guān)于react+typescript中使用echarts的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)react typescript中使用echarts內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Hello?React的組件化方式之React入門小案例演示
這篇文章主要介紹了Hello?React的組件化方式-React入門小案例,本文通過(guò)Hello?React的案例,?來(lái)體驗(yàn)一下React開(kāi)發(fā)模式,?以及jsx的語(yǔ)法,需要的朋友可以參考下2022-10-10
redux持久化之redux-persist結(jié)合immutable使用問(wèn)題
這篇文章主要為大家介紹了redux持久化之redux-persist結(jié)合immutable使用問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
React 首頁(yè)加載慢問(wèn)題性能優(yōu)化案例詳解
這篇文章主要介紹了React 首頁(yè)加載慢問(wèn)題性能優(yōu)化案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
React中使用echarts-for-react的方法示例
echarts-for-react則是ECharts在React生態(tài)中的官方封裝組件,它讓開(kāi)發(fā)者能夠輕松地在React應(yīng)用中集成ECharts圖表,本文就來(lái)介紹一下echarts-for-react的使用,感興趣的可以了解一下2025-03-03
react-native android狀態(tài)欄的實(shí)現(xiàn)
這篇文章主要介紹了react-native android狀態(tài)欄的實(shí)現(xiàn),使?fàn)顟B(tài)欄顏色與App顏色一致,使用戶界面更加整體。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
React實(shí)現(xiàn)父組件調(diào)用子組件的兩種寫(xiě)法
react通信分很多種,比如:父子通信,兄弟通信等等,這里我們就簡(jiǎn)單說(shuō)一下父子通信,父子通信分為:父組件調(diào)用子組件里面的方法;子組件調(diào)用子組件里面的方法,這里我們著重說(shuō)一下父組件調(diào)用子組件,需要的朋友可以參考下2024-04-04
詳解webpack + react + react-router 如何實(shí)現(xiàn)懶加載
這篇文章主要介紹了詳解webpack + react + react-router 如何實(shí)現(xiàn)懶加載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-11-11

