原生小程序使用echarts

下载

首先,下载 GitHub 上的 ecomfe/echarts-for-weixin 项目。

引入组件

拷贝 ec-canvas 目录,参考下面几个文件的写法。

json 配置如下:

复制代码
 "usingComponents": {
    "ec-canvas": "/ec-canvas/ec-canvas"
  }

wxml 中:

复制代码
<view class="ec-container">
    <ec-canvas canvas-id="echart-pie" ec="{{ec}}"></ec-canvas>
</view>

js 中:

复制代码
// home.js
import * as echarts from '../../ec-canvas/echarts';

Page({
  data: {
    // 1. 只传函数引用,不要加 ()
    ec: {
      onInit: initChart
    }
  },

  onLoad() {
    // 可以在这里发起网络请求,动态改 option
  },

  onReady() {
    // 页面首次渲染完成
  },

  onShow() { },
  onHide() { },
  onUnload() { },
  onPullDownRefresh() { },
  onReachBottom() { },

  // 右上角分享
  onShareAppMessage() {
    return {
      title: '城市销量占比',
      path: '/pages/home/home'
    };
  }
});

/* ======================================================
 * 初始化函数,由 ec-canvas 组件在渲染后自动调用
 * ====================================================== */
function initChart(canvas, width, height, dpr) {
  const chart = echarts.init(canvas, null, {
    width,
    height,
    devicePixelRatio: dpr
  });

  canvas.setChart(chart);   // 兼容 v2 组件库

  const option = {
    backgroundColor: '#ffffff',
    series: [{
      type: 'pie',
      center: ['50%', '50%'],
      radius: ['20%', '40%'],
      label: {
        fontSize: 14
      },
      data: [
        { value: 55, name: '北京' },
        { value: 20, name: '武汉' },
        { value: 10, name: '杭州' },
        { value: 20, name: '广州' },
        { value: 38, name: '上海' }
      ]
    }]
  };

  chart.setOption(option);
  return chart;   // 必须返回 chart 实例
}

scss中:

复制代码
.ec-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 100vh;
}

ec-canvas {
  width: 100%;
  height: 100%;
}
相关推荐
lbh21 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
We་ct1 天前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
wefly20171 天前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒1 天前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro1 天前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳1 天前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授1 天前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
zayzy1 天前
前端八股总结
开发语言·前端·javascript
今天减肥吗1 天前
前端面试题
开发语言·前端·javascript
Rabbit_QL1 天前
【前端UI行话】前端 UI 术语速查表
前端·ui·状态模式