真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ReactNative中如何利用echarts畫圖表

這篇文章主要講解了“React Native中如何利用echarts畫圖表”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“React Native中如何利用echarts畫圖表”吧!

成都創(chuàng)新互聯(lián)服務項目包括南部網(wǎng)站建設、南部網(wǎng)站制作、南部網(wǎng)頁制作以及南部網(wǎng)絡營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯(lián)網(wǎng)行業(yè)的解決方案,南部網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務的客戶以成都為中心已經(jīng)輻射到南部省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!

小提示

  • 如果你已經(jīng)有 APP 包,可以忽略前面的打包流程,直接跳到第 4 步。

詳細使用過程如下

1、開發(fā)環(huán)境搭建

本地搭好 RN 開發(fā)環(huán)境,搭建過程網(wǎng)上一抓一大把,就不贅述了。

2、準備 RN 工程

因為是試用,所以我用 expo 新初始化了一個 rn 工程,叫 TestApp。

npx create-expo-app TestApp

React Native中如何利用echarts畫圖表

3、build App 包

用命令行生成包 ios android app 包。這里 ios 建議用模擬器(不需要配證書),安卓我是連的真機

yarn android
yarn ios

生成包后,手機看到已經(jīng)安裝了這個應用,就代表成功啦。

React Native中如何利用echarts畫圖表

4、 安裝相關依賴

yarn add @wuba/react-native-echarts echarts
yarn add @shopify/react-native-skia
yarn add react-native-svg

注意,如果你是在已有工程中安裝,安裝完成后要重新打個新包,不然缺少原生依賴會報錯;

5、試用 Skia 模式

@wuba/react-native-echarts 支持兩種渲染模式(Skia 和 Svg),先用 Skia 試一個簡單的圖表。大致分為這幾個小步驟:

  • 引入 echarts、圖表組件等依賴

  • 注冊圖表組件

  • 創(chuàng)建圖表實例,并設置圖表的配置(option)

  • 頁面銷毀時要記得同步銷毀圖表實例

具體代碼如下:

import { useRef, useEffect } from 'react';
import { View } from 'react-native';
/**
 * 一、引入echarts依賴,這里先試下折線圖
 */
import * as echarts from 'echarts/core';
import { LineChart } from 'echarts/charts';
import { GridComponent } from 'echarts/components';
import { SVGRenderer, SkiaChart } from '@wuba/react-native-echarts';

/**
 * 二、注冊需要用到的組件
 * SVGRenderer: 是必須注冊的
 * LineChart: 因為用的折線圖,所以要引入LineChart(如果不知道該引入哪些組件,就直接看報錯,報錯說缺什么就加什么)
 * GridComponent: 這個就是報錯的時候提示,然后我加的hhh
 */
echarts.use([SVGRenderer, LineChart, GridComponent]);

export default () => {
  const skiaRef = useRef(null); // Ref用于保存圖表實例
  useEffect(() => {
    /**
     * 四、圖表配置
     */
    const option = {
      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',
        },
      ],
    };
    let chart;
    if (skiaRef.current) {
      /**
       * 五、初始化圖表,指定下寬高
       */
      chart = echarts.init(skiaRef.current, 'light', {
        renderer: 'svg',
        width: 400,
        height: 400,
      });
      chart.setOption(option);
    }
    /**
     * 六、頁面關閉后要銷毀圖表實例
     */
    return () => chart?.dispose();
  }, []);
  return (
    
      
    
  );
};

寫完搖一搖手機,reload bundle 包時出現(xiàn)了報錯:

ERROR Invariant Violation: requireNativeComponent: "SkiaDomView" was not found in the UIManager.

google 了一下,說是需要降級解決。其實是要跟 expo 版本對應,在安裝依賴的時候也會有類似這樣的提示,安裝提示的版本就可以了

React Native中如何利用echarts畫圖表

于是按照提示做了版本降級:

@shopify/react-native-skia@0.1.157
react-native-svg@13.4.0

重新構建 app 后加載出來了,針不戳;(安卓遮住了點,看來應該自適應屏幕寬度)

iOSAndroid
React Native中如何利用echarts畫圖表React Native中如何利用echarts畫圖表

6、試用 Svg 模式

寫個復雜點的動態(tài)排序柱狀圖,試試 Svg 模式,給 Svg 和 Skia 做個對比,完整代碼看這里。

// ...此處省略一些不重要的代碼

// 注冊需要用到的組件,BarChart-柱狀圖 LegendComponent-圖例
echarts.use([SVGRenderer, BarChart, LegendComponent, GridComponent]);

export default () => {
  const skiaRef = useRef(null);
  const svgRef = useRef(null);

  useEffect(() => {
    // Skia模式
    const skiaChartData = getData(); // 生成圖表柱狀圖數(shù)據(jù)
    let skiaChart;
    let skiaInter;
    if (skiaRef.current) {
      skiaChart = echarts.init(skiaRef.current, 'light', {
        renderer: 'svg',
        width: 300,
        height: 300,
      });
      skiaChart.setOption(getDefaultOption(skiaChartData));
      setTimeout(function () {
        run(skiaChart, skiaChartData);
      }, 0);
      skiaInter = setInterval(function () {
        run(skiaChart, skiaChartData);
      }, 3000);
    }

    // Svg模式
    const svgChartData = getData();
    let svgChart;
    let svgInter;
    if (svgRef.current) {
      svgChart = echarts.init(svgRef.current, 'light', {
        renderer: 'svg',
        width: 300,
        height: 300,
      });
      svgChart.setOption(getDefaultOption(svgChartData));
      setTimeout(function () {
        run(svgChart, svgChartData);
      }, 0);
      svgInter = setInterval(function () {
        run(svgChart, svgChartData);
      }, 3000);
    }

    return () => {
      skiaChart?.dispose();
      svgChart?.dispose();
      // 定時器得清理掉,不然退出頁面后還會運行
      clearInterval(skiaInter);
      clearInterval(svgInter);
    };
  }, []);
  return (
    
      skia如下
      
      svg如下
      
    
  );
};

Skia 和 Svg 模式,肉眼看不出明顯差別

iOSAndroid
React Native中如何利用echarts畫圖表React Native中如何利用echarts畫圖表

7、封裝 Chart 組件

效果不錯,不過每次使用都要把一堆東西引進去好煩,先簡單封裝下吧

import { useRef, useEffect } from 'react';
import * as echarts from 'echarts/core';
import { BarChart, LineChart, PieChart } from 'echarts/charts';
import {
  DataZoomComponent,
  GridComponent,
  LegendComponent,
  TitleComponent,
  ToolboxComponent,
  TooltipComponent,
} from 'echarts/components';
import {
  SVGRenderer,
  SvgChart as _SvgChart,
  SkiaChart as _SkiaChart,
} from '@wuba/react-native-echarts';
import { Dimensions } from 'react-native';

// 注冊需要用到的組件
echarts.use([
  DataZoomComponent,
  SVGRenderer,
  BarChart,
  GridComponent,
  LegendComponent,
  ToolboxComponent,
  TooltipComponent,
  TitleComponent,
  PieChart,
  LineChart,
]);

// 圖表默認寬高
const CHART_WIDTH = Dimensions.get('screen').width; // 默認用手機屏幕寬度
const CHART_HEIGHT = 300;

const Chart = ({
  option,
  onInit,
  width = CHART_WIDTH,
  height = CHART_HEIGHT,
  ChartComponent,
}) => {
  const chartRef = useRef(null);

  useEffect(() => {
    let chart;
    if (chartRef.current) {
      chart = echarts.init(chartRef.current, 'light', {
        renderer: 'svg',
        width,
        height,
      });
      option && chart.setOption(option);
      onInit?.(chart);
    }
    return () => chart?.dispose();
  }, [option]);
  return ;
};

const SkiaChart = (props) => ;
const SvgChart = (props) => ;
// 對外只暴露這哥倆就行
export { SkiaChart, SvgChart };

8、多個圖表使用

封裝好了,咱就寫個多圖表同時使用的頁面看看效果。這里寫了個“電商數(shù)據(jù)分析”頁面,分別有折線圖、柱狀圖、餅圖。下方是主要代碼,用的 svg 模式。

// 頁面代碼
import { SkiaChart } from '../../components/Chart';
import { ScrollView, Text, View } from 'react-native';
import { StatusBar } from 'expo-status-bar';
import { useCallback, useEffect, useState } from 'react';
import {
  defaultActual,
  lineOption,
  salesStatus,
  salesVolume,
  userAnaly,
  getLineData,
} from './contants';
import styles from './styles';
// 開啟圖表loading
const showChartLoading = (chart) =>
  chart.showLoading('default', {
    maskColor: '#305d9e',
  });
// 關閉圖表loading
const hideChartLoading = (chart) => chart.hideLoading();

export default () => {
  const [actual, setActual] = useState(defaultActual); // 記錄實時數(shù)據(jù)

  useEffect(() => {
    // 假設循環(huán)請求數(shù)據(jù)
    const interv = setInterval(() => {
      const newActual = [];
      for (let it of actual) {
        newActual.push({
          ...it,
          num: it.num + Math.floor((Math.random() * it.num) / 100),
        });
      }
      setActual(newActual);
    }, 200);
    return () => clearInterval(interv);
  }, [actual]);

  const onInitLineChart = useCallback((myChart) => {
    showChartLoading(myChart);
    // 模擬數(shù)據(jù)請求
    setTimeout(() => {
      myChart.setOption({
        series: getLineData,
      });
      hideChartLoading(myChart);
    }, 1000);
  }, []);

  const onInitUserChart = useCallback((myChart) => {
    // 模擬數(shù)據(jù)請求,跟onInitLineChart類似
  }, []);
  const onInitSaleChart = useCallback((myChart) => {
    // 模擬數(shù)據(jù)請求,跟onInitLineChart類似
  }, []);
  const onInitStatusChart = useCallback((myChart) => {
    // 模擬數(shù)據(jù)請求,跟onInitLineChart類似
  }, []);

  const chartList = [
    ['訂單走勢', lineOption, onInitLineChart],
    ['用戶統(tǒng)計', userAnaly, onInitUserChart],
    ['各品類銷售統(tǒng)計', salesVolume, onInitSaleChart],
    ['訂單狀態(tài)統(tǒng)計', salesStatus, onInitStatusChart],
  ];

  return (
    
      
      
        
          實時數(shù)據(jù)
        
        
          {actual.map(({ title, num, unit }) => (
            
              
                {title}
              
              
                {num}
              
              
                {unit}
              
            
          ))}
        
      
      {chartList.map(([title, data, callback]) => (
        
          
            {title}
          
          
            
          
        
      ))}
    
  );
};

重新加載 bundle,看看效果圖

iOSAndroid
React Native中如何利用echarts畫圖表

渲染出來后,iOS 上交互很絲滑,安卓上交互時感覺偶爾會有卡頓(不會是因為我手機太差吧…)。

再換 Skia 模式看看

React Native中如何利用echarts畫圖表

emmm 雖然可以,但是好像中文不能正常顯示,安卓上中文都沒有顯示,iOS 則是亂碼??戳讼挛臋n,目前 skia 在安卓端還不支持中文,在 iOS 端可以通過設置字體為 'PingFang SC'顯示中文,比如:

const option = {
  title: {
    text: '我是中文',
    textStyle: {
      fontFamily: 'PingFang SC', // 指定字體類型
    },
  },
};

但是每個顯示中文的地方都要設置字體……那還是先用 svg 吧。

感謝各位的閱讀,以上就是“React Native中如何利用echarts畫圖表”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對React Native中如何利用echarts畫圖表這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!


標題名稱:ReactNative中如何利用echarts畫圖表
文章網(wǎng)址:http://weahome.cn/article/pidged.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部