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+框架中高效实现动态数据可视化。

相关推荐
原则猫3 小时前
HOOKS 背后机制
前端
码语智行3 小时前
首页导航跳转功能深度解析-系统内和系统外
前端
阿猫的故乡4 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
IManiy4 小时前
总结之Vibe Coding前端骨架
前端
JS菌4 小时前
AI Agent 沙箱双层防护体系:从权限过滤到内核隔离的完整实现
前端·人工智能·后端
Aphasia3115 小时前
从输入URL到页面展示全流程
前端·面试
我叫黑大帅5 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
abcy0712135 小时前
python pandas csv异步后台清洗前端优先返回成功信息
前端·python·pandas
IT_陈寒6 小时前
Vite这个坑我帮你踩了,动态导入居然这样才生效
前端·人工智能·后端
swipe6 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试