【微信小程序】实现引入 Echarts 并实现更新数据

0. 先言

建议多阅读其他相关的文章,毕竟微信小程序的坑蛮多的。

1. 引入依赖

首先需要使用 echarts-for-weixi 项目,下载并解压到目录。

将其项目下的 ec-canvas 目录复制到 components 目录下。

pages/demo/demo.json 下引入组件

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

2. 代码部分

布局文件,没什么多说的。

wxml 复制代码
<view class="container">
  <ec-canvas 
    id="dom-chart" 
    canvas-id="chart" 
    ec="{{ec}}"></ec-canvas>
</view>

必须配置宽高,不然不显示。

wxss 复制代码
.container {
  width: 100vw;
  min-height: 100vh;
}

#dom-chart {
  width: 100%;
  height: 200px;
}

关键代码部分(包含更新图标数据示例)

js 复制代码
// 1. 引入依赖
import * as echarts from '../../components/ec-canvas/echarts';

Page({
  data: {
    ec: {
      onInit: null
    }
  },

  chart: null,
  chartData: [
    { name: '参数1', value: 1 },
    { name: '参数2', value: 2 }
  ],

  onLoad() {
    this.initChart()
  },

  // 初始化图表
  initChart() {
    this.setData({
      'ec.onInit': (canvas, width, height, dpr) => {
        const chart = echarts.init(canvas, null, {
          width,
          height,
          devicePixelRatio: dpr
        })
        canvas.setChart(chart)

        this.chart = chart

        chart.setOption(this.getOption())

        // 初始化后再更新一次数据
        this.addData({ name: '参数3', value: 3 })

        return chart
      }
    })
  },

  // 统一的 option 生成方法
  getOption() {
    return {
      tooltip: {
        trigger: 'item'
      },
      series: [
        {
          type: 'pie',
          radius: ['40%', '70%'],
          data: this.chartData
        }
      ]
    }
  },

  // 添加数据并刷新图表
  addData(item) {
    if (!this.chart) return

    this.chartData.push(item)

    this.chart.setOption({
      series: [
        {
          data: this.chartData
        }
      ]
    })
  },

  onUnload() {
    this.chart?.dispose()
    this.chart = null
  }
})

结束。

相关推荐
计算机徐师兄11 小时前
Java基于微信小程序的食堂线上预约点餐系统【附源码、文档说明】
java·微信小程序·食堂线上预约点餐系统小程序·食堂线上预约点餐微信小程序·java食堂线上预约点餐小程序·食堂线上预约点餐小程序·食堂线上预约点餐系统微信小程序
毕设源码-邱学长1 天前
【开题答辩全过程】以 基于微信小程序的松辽律所咨询系统的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
计算机毕设指导61 天前
基于微信小程序的钓鱼论坛系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
qq_12498707531 天前
基于微信小程序的宠物交易平台的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计
kyh10033811201 天前
第二个微信小游戏《汉字碰碰消》上线啦!
微信·微信小程序·微信小游戏·去水印微信小程序·养了个羊
计算机毕设指导61 天前
基于微信小程序的精致护肤购物系统【源码文末联系】
java·spring boot·微信小程序·小程序·tomcat·maven·intellij-idea
myzshare2 天前
实战分享:我是如何用SSM框架开发出一个完整项目的
java·mysql·spring cloud·微信小程序
sheji34162 天前
【开题答辩全过程】以 基于微信小程序的在线学习系统为例,包含答辩的问题和答案
学习·微信小程序·小程序
是江迪呀2 天前
小程序上线半年我赚了多少钱?
微信小程序·产品·创业
三天不学习2 天前
UniApp三端实时通信实战:SignalR在H5、APP、小程序的差异与实现
微信小程序·uni-app·signalr