原生小程序使用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%;
}
相关推荐
kyriewen9 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒10 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮10 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦10 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer11 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队11 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY11 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_11 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏12 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站12 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控