react-native-echarts在打包時出現的坑


  react-native-echarts目前是RN開發中使用echarts圖表最好的插件了,用法與Echarts完全一致,默認提供了三個屬性:

  • option (object): The option for echarts: Documentation
  • width (number): The width of the chart. The default value is the outer container width.
  • height (number): The height of the chart. The default value is 400

  1.首先是最基本的使用:

    

import React, { Component } from 'react'; import { AppRegistry, StyleSheet, Text, View } from 'react-native'; import Echarts from 'native-echarts'; export default class app extends Component { render() { const option = { title: { text: 'ECharts demo' }, tooltip: {}, legend: { data:['銷量'] }, xAxis: { data: ["襯衫","羊毛衫","雪紡衫","褲子","高跟鞋","襪子"] }, yAxis: {}, series: [{ name: '銷量', type: 'bar', data: [5, 20, 36, 10, 10, 20] }] }; return ( <Echarts option={option} height={300} /> ); } } AppRegistry.registerComponent('app', () => app);

當自定義tooltip時,由於react-native-echarts外層包裹了一層WebView,所以在配置項的函數內部不能拿到外部的變量

const deviceW = Dimensions.get('window').width / 750
 
option.tooltip.formatter = (params) => {
  return `<div style="width: ${deviceW*690}px; font-size: ${deviceW*26}px;"></div>` // 此處deviceW並不生效,獲取不到外部定義的變量
}

  2.改進:

    WebView將圖表與外界的變量進行了隔離,只能另想他法,多傳入一個屬性,將外部變量變成可以供內部使用的變量

    

const deviceW = Dimensions.get('window').width / 750
let chartContext = {
  width: deviceW
}
 option.tooltip.formatter = (params) => {
  return `<div style="width: ${chartContext.width*690}px; font-size: ${chartContext.width*26}px;"></div>` // 此處deviceW並不生效,獲取不到外部定義的變量
 }
<Echarts option={option} height={300} chartContext={chartContext} />

// 修改react-native-echarts包代碼:
// renderChart.js
 export default function renderChart(props) {
  const height = `${props.height || 400}px`;
  const width = props.width ? `${props.width}px` : "auto";
   const chartContext = props.chartContext
  return `
    document.getElementById('main').style.height = "${height}";
    document.getElementById('main').style.width = "${width}";
    var myChart = echarts.init(document.getElementById('main'));
     var chartContext = ${toString(chartContext)};
    myChart.setOption(${toString(props.option)});
    myChart.on('click', function(params) {
      var seen = [];
      var paramsString = JSON.stringify(params, function(key, val) {
        if (val != null && typeof val == "object") {
          if (seen.indexOf(val) >= 0) {
            return;
          }
          seen.push(val);
        }
        return val;
      });
      window.postMessage(paramsString);
    });
    `
 }

  3.改進:

    以上方案解決了配置項拿不到外部變量的問題,看起來很完美,運行代碼也沒有什么問題,不過,在項目打包時,又出了問題,圖表顯示不出來了,很詭異

    原因:打包時,由於自定義屬性是手動加的,打包時轉換成了簡寫,不能被識別

  

  

// renderChart.js
var chartContext = ${toString(chartContext)}; 替換為
var g_chartContext = ${toString(chartContext)};
  
// 使用時,把chartContext 全都替換為g_chartContext 就可以了
  
option.tooltip.formatter = (params) => {
  return `<div style="width: ${ g_chartContext.width*690}px; font-size: ${ g_chartContext.width*26}px;"></div>` // 此處deviceW並不生效,獲取不到外部定義的變量
}

   4.終極版:

import resolveAssetSource from 'react-native/Libraries/Image/resolveAssetSource';

export default class Assets {

    static fromModule(moduleId) {
        return resolveAssetSource(moduleId);
    }
}
import Assets from 'emrn-common/utils/assets'

<WebView
  ref="chart"
  scrollEnabled={false}
  injectedJavaScript={renderChart(this.props)}
  originWhitelist={['*']}
  style={{
     height: this.props.height || 400,
     backgroundColor: this.props.backgroundColor || 'transparent'
  }}
  scalesPageToFit={Platform.OS === 'android'}
  // source={{ html: tpl, baseUrl: '' }}
   // source={source}
  source={{uri: Assets.fromModule(source).uri}}
  // onMessage={event => this.props.onPress ? this.props.onPress(JSON.parse(event.nativeEvent.data)) : null}
  />

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM