欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React之echarts-for-react源碼解讀

 更新時(shí)間:2022年10月15日 09:07:25   作者:肥仔John  
這篇文章主要介紹了React之echarts-for-react源碼解讀,echarts-for-react的源碼非常精簡,本文將針對主要邏輯分析介紹,需要的朋友可以參考下

前言

在當(dāng)前工業(yè)4.0和智能制造的產(chǎn)業(yè)升級浪潮當(dāng)中,智慧大屏無疑是展示企業(yè)IT成果的最有效方式之一。然而其背后怎么能缺少ECharts的身影呢?對于React應(yīng)用而言,直接使用ECharts并不是最高效且優(yōu)雅的方式,而echarts-for-react則是針對React應(yīng)用對ECharts進(jìn)行輕量封裝和增強(qiáng)的工具庫。

echarts-for-react的源碼非常精簡,本文將針對主要邏輯分析介紹。

從與原生初始化對比開始

原生ECharts中我們會通過如下代碼初始化圖表實(shí)例

<div id="container" style="width: 100px; height: 100px"></div>
<script>
  const chart = echarts.init(document.getElementById('container'))
</script>

那么生成的HTML Element結(jié)構(gòu)為

<div id="container" style="width: 100px; height: 100px" _echarts_instance=".....">
  <div style="width: 100px; height: 100px;position: relative;">
    <canvas width="100" height="100"></canvas>
  </div>
</div>

其中第二層的div和canvas的寬高默認(rèn)為容器div#container的寬高,我們可以通過init入?yún)⒅付▋烧邔挾取?/p>

const chart = echarts.init(
  document.getElementById('container'), 
  null, 
  { 
    width: 300, // 可顯式指定實(shí)例寬度,單位為像素。如果傳入值為null/undefined/'auto',則表示自動取 dom(實(shí)例容器)的寬度
    height: 300 // 可顯式指定實(shí)例高度,單位為像素。如果傳入值為null/undefined/'auto',則表示自動取 dom(實(shí)例容器)的高度
  }
)

注意:若此時(shí)容器div#container尺寸發(fā)生變化,第二層div和canvas尺寸并不會自適應(yīng),需要我們手工調(diào)用chart.resize()觸發(fā)。

而通過echarts-for-react上述步驟將被簡化為如下,并且生成相同的HTML Element結(jié)構(gòu):

import ReactECharts from 'echarts-for-react'

function Demo() {
  return (
    <ReactECharts
      style={{width: 100, height: 100}} // 設(shè)置容器的寬高
      autoResize={true} // 默認(rèn)為true,自動監(jiān)測容器尺寸的變化,并調(diào)用`chart.resize()`
    />
  )
}

陷阱-默認(rèn)值height為300px

由于ReactEChartsstyle默認(rèn)內(nèi)置height: 300,源碼如下:

// src/core.tsx

render(): JSX.Element {
  const { style, className = '' } = this.props
  const newStyle = { height: 300, ...style }

  return (
    <div
      ref={(e: HTMLElement) => {
        this.ele = e
      }}
      style={newStyle}
      className={`echarts-for-react ${className}`}
    />
  )
}

因此通過className的方式設(shè)置容器高度時(shí)必須使用!important

<ReactECharts
  className={styles.container}
/>
// index.module.css
.container {
  height: 500px !important;
}

獲取ECharts實(shí)例

const ref = useRef()

useEffect(() => {
  const instance = ref.current.getEchartsInstance()
}, [])

<EchartsReact
  ref={ref}
/>

主邏輯源碼剖析

核心邏輯均在EChartsReactCore組件上(位于文件src/core.tsx),特點(diǎn)如下:

  • 采用PureComponent方式編寫組件以便適配所有React版本;
  • 僅對ECharts 命令式API進(jìn)行聲明式API的封裝,并沒有將每種EChart圖表類型封裝為組件;
  • 添加特性,監(jiān)測容器尺寸的變化,并自動調(diào)用ECharts實(shí)例的resize方法實(shí)現(xiàn)自適應(yīng)。

掛載渲染過程

  • componentDidMount時(shí)調(diào)用renderNewEcharts方法執(zhí)行ECharts組件的生成邏輯;
  • renderNewEcharts方法內(nèi)部邏輯

    通過echarts.getInstanceByDom(容器DOM元素)echarts.init(容器DOM元素,主題,配置)獲取已有ECharts實(shí)例或生成新的ECharts實(shí)例;

    通過ECharts實(shí)例的setOption方法設(shè)置或更新圖表內(nèi)容;

    通過ECharts實(shí)例的showLoadinghideLoading控制圖表渲染前是否顯示加載進(jìn)度條;

    將通過props onEvents配置的ECharts支持的事件處理器綁定到ECharts實(shí)例上;

    觸發(fā)props onChartsReady 方法;

    訂閱通過size-sensor監(jiān)測容器尺寸并自動調(diào)用ECharts實(shí)例的resize方法,實(shí)現(xiàn)圖表尺寸的自適應(yīng)。

更新渲染過程

由于render方法無論執(zhí)行多少遍,實(shí)際上僅僅有可能影響容器本身而已,對ECharts實(shí)例并沒有任何影響。因此實(shí)際影響ECharts實(shí)例的邏輯被放置到componentDidUpdate那里,這做法和react-amap中在useEffect中通過Marker等實(shí)例內(nèi)置的set方法更新狀態(tài)的原理是一致的。

  • 若更新的props包含themeoptsonEvents則要銷毀原來的ECharts實(shí)例,重新構(gòu)建一個(gè)新的ECharts實(shí)例,并終止更新渲染過程;否則執(zhí)行第2步。
  • 若props中的option,notMergela,lazyUpdate,showLoadingloadingOption均沒有變化,則不更新ECharts實(shí)例;
    注意:EChartsReactCore繼承PureComponent,若上述props進(jìn)行shallow equal比較為true時(shí)也不會更新ECharts實(shí)例;但這一步采用deep equal比較,來減少ECharts實(shí)例的更新。
  • 若props中的styleclassName發(fā)生變化則會觸發(fā)ECharts實(shí)例的resize方法。

卸載過程

  • 取消通過size-sensor訂閱的容器尺寸變化事件;
  • 通過ECharts實(shí)例的dispose方法注銷ECharts實(shí)例。

項(xiàng)目依賴

fast-deep-equal: 遍歷對象屬性進(jìn)行對比size-sensor: DOM元素尺寸監(jiān)聽器,當(dāng)元素尺寸變化時(shí)會觸發(fā)回調(diào)函數(shù)

后續(xù)

echarts-for-react利用size-sensor實(shí)現(xiàn)圖表尺寸自適應(yīng)容器尺寸,那么size-sensor是怎樣做到這一點(diǎn)呢?敬請期待一下篇《React魔法堂:size-sensor源碼略讀》。

到此這篇關(guān)于React之echarts-for-react源碼解讀的文章就介紹到這了,更多相關(guān)echarts-for-react源碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解如何構(gòu)建自己的react hooks

    詳解如何構(gòu)建自己的react hooks

    我們組的前端妹子在組內(nèi)分享時(shí)談到了 react 的鉤子,趁此機(jī)會我也對我所理解的內(nèi)容進(jìn)行下總結(jié),方便更多的同學(xué)了解。在 React 的 v16.8.0 版本里添加了 hooks 的這種新的 API,我們非常有必要了解下他的使用方法,并能夠結(jié)合我們的業(yè)務(wù)編寫幾個(gè)自定義的 hooks。
    2021-05-05
  • JavaScript中React面向組件編程(上)

    JavaScript中React面向組件編程(上)

    本文主要介紹了React組件中默認(rèn)封裝了很多屬性,有的是提供給開發(fā)者操作的,其中有三個(gè)屬性非常重要:state、props、refs。感興趣的小伙伴可以參考閱讀
    2023-03-03
  • React?路由使用示例詳解

    React?路由使用示例詳解

    這篇文章主要介紹了React?路由使用,使用路由時(shí)需要為組件指定一個(gè)路由的path,最終會以path為基礎(chǔ),進(jìn)行頁面的跳轉(zhuǎn),具體使用先看個(gè)簡單示例,該示例比較簡單就是兩個(gè)Tab頁面的來回切換
    2022-05-05
  • webpack3+React 的配置全解

    webpack3+React 的配置全解

    本篇文章主要介紹了webpack3+React 的配置全解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • 前端 react 實(shí)現(xiàn)圖片上傳前壓縮(縮率圖)

    前端 react 實(shí)現(xiàn)圖片上傳前壓縮(縮率圖)

    這篇文章主要介紹了前端 react 實(shí)現(xiàn)圖片上傳前壓縮(縮率圖),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • 關(guān)于antd tree和父子組件之間的傳值問題(react 總結(jié))

    關(guān)于antd tree和父子組件之間的傳值問題(react 總結(jié))

    這篇文章主要介紹了關(guān)于antd tree 和父子組件之間的傳值問題,是小編給大家總結(jié)的一些react知識點(diǎn),本文通過一個(gè)項(xiàng)目需求實(shí)例代碼詳解給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-06-06
  • 前端開發(fā)使用Ant Design項(xiàng)目評價(jià)

    前端開發(fā)使用Ant Design項(xiàng)目評價(jià)

    這篇文章主要為大家介紹了前端開發(fā)使用Ant Design項(xiàng)目評價(jià),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • React-native橋接Android原生開發(fā)詳解

    React-native橋接Android原生開發(fā)詳解

    本篇文章主要介紹了React-native橋接Android原生開發(fā)詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • react+antd實(shí)現(xiàn)動態(tài)編輯表格數(shù)據(jù)

    react+antd實(shí)現(xiàn)動態(tài)編輯表格數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了react+antd實(shí)現(xiàn)動態(tài)編輯表格數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • React從Class方式轉(zhuǎn)Hooks詳解

    React從Class方式轉(zhuǎn)Hooks詳解

    這篇文章主要介紹了React從Class方式轉(zhuǎn)Hooks詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09

最新評論