【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)

简介: 【微信小程序-原生开发】实用教程22 - 绘制图表(引入 echarts,含图表的懒加载-获取到数据后再渲染图表,多图表加载等技巧)

最终效果预览

实现流程

微信小程序中使用 echarts 需使用官方提供的 ec-canvas 组件

1. 下载 ec-canvas 组件

点击下方链接,下载 ec-canvas 组件

https://gitcode.net/mirrors/ecomfe/echarts-for-weixin/-/tree/master

将其中的 ec-canvas 文件夹拷贝到微信小程序的分包中

( 因 ec-canvas 组件较大,约 1M,若放在主包中很容易超出 2M 的大小限制,不了解分包的朋友,可以参考博文 https://blog.csdn.net/weixin_41192489/article/details/130249743)

2. 引入 ec-canvas 组件

package1\pages\account\statistics\index.json

{
  "navigationBarTitleText": "记账统计",
  "usingComponents": {
    "t-collapse": "tdesign-miniprogram/collapse/collapse",
    "t-collapse-panel": "tdesign-miniprogram/collapse-panel/collapse-panel",
    "ec-canvas": "/package1/ec-canvas/ec-canvas"
  }
}

其中的核心代码为

"ec-canvas": "/package1/ec-canvas/ec-canvas"

3. 页面中使用 ec-canvas 组件

package1\pages\account\statistics\index.wxml

<view class="titleBox">
  {{year}} 年{{month}} 月
</view>
<t-collapse value="{{activeValues}}" bind:change="cardChange">
  <t-collapse-panel value="{{0}}" header="收入( 合计 {{sumIn}} 元 )" expandIcon>
    <view hidden="{{hideInChart}}" class="container">
      <ec-canvas id="mychart1" canvas-id="mychart1" ec="{{ ec }}"></ec-canvas>
    </view>
  </t-collapse-panel>
  <t-collapse-panel value="{{1}}" header="支出( 合计 {{sumOut}} 元 )" expandIcon>
    <view hidden="{{hideOutChart}}" class="container">
      <ec-canvas id="mychart2" canvas-id="mychart2" ec="{{ ec }}"></ec-canvas>
    </view>
  </t-collapse-panel>
</t-collapse>

核心代码为

<ec-canvas id="mychart1" canvas-id="mychart1" ec="{{ ec }}"></ec-canvas>

此范例为一个页面渲染多个图表,需留意每个组件需有不同的 id

      <ec-canvas id="mychart2" canvas-id="mychart2" ec="{{ ec }}"></ec-canvas>

4. 添加必要的 css

ec-canvas 组件默认没有尺寸,需手动添加必要的 css,才能显示。

package1\pages\account\statistics\index.wxss

.container {
  position: relative;
  width: 98%;
  height: 500rpx;
  margin: 0rpx auto;
}

ec-canvas {
  position: relative;
  width: 300rpx;
  height: 400rpx;
}

.titleBox {
  font-weight: bold;
  padding-top: 30rpx;
  font-size: 40rpx;
  text-align: center;
}

5. 获取数据,渲染图表

package1\pages\account\statistics\index.js

import * as echarts from '../../../ec-canvas/echarts';

Page({
  data: {
    // 数据列表
    dataList: [],
    // 是否隐藏收入图表
    hideInChart: false,
    // 是否隐藏支出图表
    hideOutChart: false,
    // 折叠卡片的值
    activeValues: [0, 1],
    // 图表配置
    ec: {
      // 图表懒加载的必要参数
      lazyLoad: true
    },
    // 收入类型
    inTypeList: ['工资', '兼职', '理财', '其他收入'],
    // 支出类型
    outTypeList: ['衣', '食', '住', '行', '娱', '医', '学', '其他支出']
  },
  // 折叠卡片切换
  cardChange(e) {
    this.setData({
      activeValues: e.detail.value,
    });
    this.updateData()
  },
  // 更新数据状态(控制图表的显隐)
  updateData() {
    let {
      activeValues
    } = this.data
    this.setData({
      hideInChart: !activeValues.includes(0),
      hideOutChart: !activeValues.includes(1)
    })
  },
  // 分类统计收入数据
  getInResult(dataList) {
    let {
      inTypeList
    } = this.data

    let inResultDic = {}

    dataList.forEach(item => {
      inTypeList.forEach(type => {
        if (!inResultDic[type]) {
          inResultDic[type] = 0
        }
        if (item.type === type) {
          inResultDic[type] += item.money
        }
      })
    })
    let yDataList = []

    inTypeList.forEach(type => {
      yDataList.push(inResultDic[type] || 0)
    })

    this.drawChart(this.ecComponent1, inTypeList, yDataList)
  },
  // 分类统计支出数据
  getOutResult(dataList) {
    let {
      outTypeList
    } = this.data

    let outResultDic = {}

    dataList.forEach(item => {
      outTypeList.forEach(type => {
        if (!outResultDic[type]) {
          outResultDic[type] = 0
        }
        if (item.type === type) {
          outResultDic[type] += item.money
        }
      })
    })
    let yDataList = []

    outTypeList.forEach(type => {
      yDataList.push(outResultDic[type] || 0)
    })
    // 因页面宽度有限,删除支出二字
    outTypeList[7] = '其他'
    this.drawChart(this.ecComponent2, outTypeList, yDataList)
  },
  onLoad() {
    let that = this
    // 接收传入的复杂数据
    const eventChannel = this.getOpenerEventChannel()
    eventChannel.on('sendData', function (res) {
      let {
        sumIn,
        sumOut,
        sumResult,
        year,
        month,
        dataList
      } = res
      that.setData({
        sumIn,
        sumOut,
        // 月结余
        balance: sumResult,
        year,
        month,
        dataList
      })
      that.ecComponent1 = that.selectComponent('#mychart1');
      that.ecComponent2 = that.selectComponent('#mychart2');
      that.getInResult(dataList)
      that.getOutResult(dataList)
    })
  },
  // 绘制图表
  drawChart(ecComponent, xDataList, yDataList) {
    ecComponent.init((canvas, width, height, dpr) => {
      // 获取组件的 canvas、width、height 后的回调函数
      // 在这里初始化图表
      const chart = echarts.init(canvas, null, {
        width: width,
        height: height,
        devicePixelRatio: dpr
      });
      this.setOption(chart, xDataList, yDataList);

      // 注意这里一定要返回 chart 实例,否则会影响事件处理等
      return chart;
    });
  },
  // 柱状图配置
  setOption(chart, xDataList, yDataList) {
    let option = {
      xAxis: {
        type: 'category',
        data: xDataList
      },
      yAxis: {
        type: 'value'
      },
      series: [{
        data: yDataList,
        type: 'bar',
        label: {
          show: true,
          position: "top"
        }
      }]
    }
    chart.setOption(option);
  }
})

核心代码解析

  • 导入 echarts
import * as echarts from '../../../ec-canvas/echarts';
  • 获取页面图表节点
that.ecComponent1 = that.selectComponent('#mychart1');
  • 绘制图表
  // 绘制图表
  drawChart(ecComponent, xDataList, yDataList) {
    ecComponent.init((canvas, width, height, dpr) => {
      // 获取组件的 canvas、width、height 后的回调函数
      // 在这里初始化图表
      const chart = echarts.init(canvas, null, {
        width: width,
        height: height,
        devicePixelRatio: dpr
      });
      this.setOption(chart, xDataList, yDataList);

      // 注意这里一定要返回 chart 实例,否则会影响事件处理等
      return chart;
    });
  },
  • 添加图表配置
  setOption(chart, xDataList, yDataList) {
    let option = {
      xAxis: {
        type: 'category',
        data: xDataList
      },
      yAxis: {
        type: 'value'
      },
      series: [{
        data: yDataList,
        type: 'bar',
        label: {
          show: true,
          position: "top"
        }
      }]
    }
    chart.setOption(option);
  }

https://echarts.apache.org/examples/zh/index.html

目录
相关文章
|
JSON JavaScript 定位技术
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
vue中使用echarts实现省市地图绘制,根据数据显示省市天气图标及温度信息
1772 1
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
4170 1
|
10月前
|
JSON 机器人 API
gewe微信机器人搭建教程
GeWe开放平台是基于 微信开放平台的二次封装API服务,开发者可以使用本服务来处理微信中的各种事件,并可以通过后台调用对应的 API 来驱动微信自动执行任务,如自动收发消息、自动化应答、自动群邀请、群管理等,封装了 RPA技术流程,简化开发者二次开发难度,提供了开发者与微信对接的能力,使用简单,操作快捷,支持多种语言接入。
641 17
|
人工智能 开发框架 机器人
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
AstrBot 是一个开源的多平台聊天机器人及开发框架,支持多种大语言模型和消息平台,具备多轮对话、语音转文字等功能。
7774 38
AstrBot:轻松将大模型接入QQ、微信等消息平台,打造多功能AI聊天机器人的开发框架,附详细教程
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
3549 11
技术小白如何利用DeepSeek半小时开发微信小程序?
|
JSON 小程序 数据格式
微信小程序默认的文字内容在左上角怎么办?带你0基础快速了解skyline渲染模式。
本文主要介绍微信小程序开发中遇到的问题及其解决方法。问题通常由微信小程序自带的Skyline渲染模式引起,而非代码编写错误。解决步骤包括:1. 找到全局配置文件app.json;2. 去掉相关配置项;3. 修改后的配置示例。通过这些步骤可以有效解决文字内容顶格或覆盖的问题。文中还提供了进一步了解Skyline渲染模式的链接,帮助开发者深入理解其原理和应用。
1333 59
|
11月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
11月前
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
小程序 JavaScript 前端开发
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
14194 14
|
存储 API UED
鸿蒙特效教程02-微信语音录制动画效果实现教程
本教程适合HarmonyOS初学者,通过简单到复杂的步骤,一步步实现类似微信APP中的语音录制动画效果。
466 0
鸿蒙特效教程02-微信语音录制动画效果实现教程

热门文章

最新文章