Taro3+ React小程序中实现echarts图表 ec-canvas(echarts-for-weixin)

一、环境准备与组件引入

1. 获取官方组件库

从GitHub下载 echarts-for-weixin 项目,将 ec-canvas 文件夹复制到Taro项目 /src/components 目录下(需保证路径层级合理)

2. 修复兼容性问题

在这里我们会遇到一个报错修改 ec-canvas/echarts.js 文件,找到以下代码:t.addEventListener(e, n, i)

改为:t.addEventListener?.(e, n, i) // 增加可选链操作符避免Taro编译报错

3.#### 定制化构建ECharts

  1. 访问 ECharts在线构建器

  2. 仅勾选需要的图表类型(如折线图、柱状图)

  3. 下载生成的 echarts.min.js 并替换项目中的 ec-canvas/echarts.js 可使包体积从1MB+降至300KB左右。选自己常用的图表。

二、Taro项目配置

config/index.js 中添加小程序编译配置:

javascript 复制代码
const config = { mini: { postcss: { /*...*/ }, // 允许引入原生小程序组件
                compile: { exclude: [ /src/components/ec-canvas/ // 排除ec-canvas编译 ] }
     } }

2. 页面组件声明

在需要使用图表的页面配置文件 页面名.config.js 中声明组件(一定是要用相对地址 不然就会报错或者渲染不出来)

arduino 复制代码
export default { navigationBarTitleText: '图表页',
  usingComponents: { "ec-canvas": "../../components/ec-canvas/ec-canvas" } 
 }

三、基础图表实现

1. WXML结构

2. 样式设置一定要设置高度

3. 图表初始化逻辑

五、性能优化技巧

1. 定制化构建ECharts

  1. 访问 ECharts在线构建器

  2. 仅勾选需要的图表类型(如折线图、柱状图)

  3. 下载生成的 echarts.min.js 并替换项目中的 ec-canvas/echarts.js 可使包体积从1MB+降至300KB左右 。

2. 分包加载策略

ec-canvas 组件放入分包目录:

配置分包路由后,主包体积可减少约1MB

六、常见问题解决

  1. 图表不渲染

    • 检查组件路径是否正确(90%的问题源于路径错误)

    • 确保容器设置了明确宽高

  2. 滑动时图表抖动 添加 force-use-old-canvas="true" 属性

  3. TypeError: t.addEventListener is not a function 修改 ec-canvas/echarts.js 文件,找到以下代码:t.addEventListener(e, n, i)修改为t.addEventListener?.(e, n, i)

  4. 包体积超标 使用定制构建+分包策略,可缩减至300-500KB

  5. TypeError: this.Chart.init is not a function Taro3 不能通过ref直接获取原生微信小程序组件,实际获取的是 TaroElement, 通过 getCurrentInstance().page.selectComponent('#mychart-area') 方式获取微信原生小程序

ini 复制代码
 // 初始化图表
  const initChart = useCallback(
    (canvas, width, height, dpr) => {
      const chart = echarts.init(canvas, undefined, {
        width,
        height,
        devicePixelRatio: dpr,
      });
      updateChart(chart);
      chartRef.current = chart;
      return chart;
    },
    [updateChart]
  );

 // 初始化逻辑调整
 useEffect(() => {
    const pageCtx = getCurrentInstance().page;
    setTimeout(() => {
      // 初始化雷达图
      ecCanvasRef.current = pageCtx.selectComponent("#radar-canvas");
      ecCanvasRef.current?.init(initChart);

      // 初始化柱状图
      barEcCanvasRef.current = pageCtx.selectComponent("#bar-canvas");
      barEcCanvasRef.current?.init(initBarChart);
    }, 300);

    return () => {
      chartRef.current?.dispose();
      barChartRef.current?.dispose();
    };
  }, [initChart, initBarChart]);
  1. tooltip在小程序中文字有黑色阴影 设置tooltip.shadowBlur = 0 7. 小程序里echarts生成的canvas层级太高 在微信开发工具中可能展示不出来 但是在真机调试中就有这问题 解决办法 去除force-use-old-canvas

通过以上步骤,开发者可在Taro3.0+框架中高效实现动态数据可视化。

相关推荐
阿里小阿希19 分钟前
解决 pnpm dev 运行报错的坎坷历程
前端·node.js
未脱发程序员30 分钟前
分享一款开源的图片去重软件 ImageContrastTools,基于Electron和hash算法
前端·javascript·electron
视频砖家1 小时前
Web前端VSCode如何解决打开html页面中文乱码的问题(方法2)
前端·vscode·vscode乱码·vscode中文乱码·vscode中文编码
2401_837088501 小时前
CSS transition过渡属性
前端·css
我爱吃朱肉1 小时前
深入理解 CSS Flex 布局:代码实例解析
前端·css
喝养乐多长不高1 小时前
Spring Web MVC基础理论和使用
java·前端·后端·spring·mvc·springmvc
zh73143 小时前
支付宝沙盒模式商家转账经常出现 响应异常: 解包错误
前端·阿里云·php
ZHOU_WUYI3 小时前
用react实现一个简单的三页应用
前端·javascript·react.js
samroom3 小时前
Vue项目---懒加载的应用
前端·javascript·vue.js·性能优化
手机忘记时间4 小时前
在R语言中如何将列的名字改成别的
java·前端·python