原生小程序使用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%;
}
相关推荐
玉米Yvmi2 小时前
从零理解 CSS 弹性布局:轻松掌控页面元素排布
前端·javascript·css
西洼工作室2 小时前
前端js汉字手写练习系统
前端·javascript·css
小小王app小程序开发2 小时前
盲盒小程序避坑指南:开发运营全流程风险规避策略
小程序
程序员爱钓鱼2 小时前
Node.js 编程实战:CSV&JSON &Excel 数据处理
前端·后端·node.js
徐同保2 小时前
n8n+GPT-4o一次解析多张图片
开发语言·前端·javascript
DanyHope2 小时前
LeetCode 128. 最长连续序列:O (n) 时间的哈希集合 + 剪枝解法全解析
前端·leetcode·哈希算法·剪枝
GISer_Jing2 小时前
AI赋能前端:从核心概念到工程实践的全景学习指南
前端·javascript·aigc
|晴 天|2 小时前
前端事件循环:宏任务与微任务的深度解析
前端
用户4445543654262 小时前
Android开发中的封装思路指导
前端