收藏
评论

微信小程序中可以使用 ECharts 创建图表啦!

我们接到了很多微信小程序开发者的反馈,表示他们强烈需要像 ECharts 这样的可视化工具。但是微信小程序是不支持 DOM 操作的,Canvas 接口也和浏览器不尽相同。


因此,ECharts 团队和微信小程序官方团队合作,提供了 ECharts 的微信小程序版本。开发者可以通过熟悉的 ECharts 配置方式,快速开发图表,满足各种可视化需求。


欢迎试用!如有问题,请通过 issue 反馈给我们。

在微信小程序中使用 ECharts

本项目是 ECharts 的微信小程序版本,以及使用的示例。

开发者可以通过熟悉的 ECharts 配置方式,快速开发图表,满足各种可视化需求。

体验示例小程序

在微信中扫描下面的二维码即可体验 ECharts Demo:

ECharts Demo

下载

为了兼容小程序 Canvas,我们提供了一个小程序的组件,用这种方式可以方便地使用 ECharts。

首先,下载本项目。

其中,ec-canvas 是我们提供的组件,其他文件是如何使用该组件的示例。

ec-canvas 目录下有一个 echarts.js,默认我们会在每次 echarts-for-weixin 项目发版的时候替换成最新版的 ECharts。如有必要,可以自行从 ECharts 项目中下载最新发布版,或者从官网自定义构建以减小文件大小。

引入组件

微信小程序的项目创建可以参见微信公众平台官方文档

在创建项目之后,可以将下载的 ecomfe/echarts-for-weixin 项目完全替换新建的项目,然后将修改代码;或者仅拷贝 ec-canvas 目录到新建的项目下,然后做相应的调整。

如果采用完全替换的方式,需要将 project.config.json 中的 appid 替换成在公众平台申请的项目 id。pages 目录下的每个文件夹是一个页面,可以根据情况删除不需要的页面,并且在 app.json 中删除对应页面。

如果仅拷贝 ec-canvas 目录,则可以参考 pages/bar 目录下的几个文件的写法。下面,我们具体地说明。

创建图表

首先,在 pages/bar 目录下新建以下几个文件:index.jsindex.jsonindex.wxmlindex.wxss。并且在 app.jsonpages 中增加 'pages/bar/index'

index.json 配置如下:

{
  "usingComponents": {
    "ec-canvas": "../../ec-canvas/ec-canvas"
  }
}

这一配置的作用是,允许我们在 pages/bar/index.wxml 中使用 <ec-canvas> 组件。注意路径的相对位置要写对,如果目录结构和本例相同,就应该像上面这样配置。

index.wxml 中,我们创建了一个 <ec-canvas> 组件,内容如下:

<view class="container">
  <ec-canvas id="mychart-dom-bar" canvas-id="mychart-bar" ec="{{ ec }}"></ec-canvas>
</view>

其中 ec 是一个我们在 index.js 中定义的对象,它使得图表能够在页面加载后被初始化并设置。index.js 的结构如下:

function initChart(canvas, width, height) {
  const chart = echarts.init(canvas, null, {
    width: width,
    height: height
  });
  canvas.setChart(chart);

  var option = {
    ...
  };
  chart.setOption(option);
  return chart;
}

Page({
  data: {
    ec: {
      onInit: initChart
    }
  }
});

这对于所有 ECharts 图表都是通用的,用户只需要修改上面 option 的内容,即可改变图表。option 的使用方法参见 ECharts 配置项文档。对于不熟悉 ECharts 的用户,可以参见 5 分钟上手 ECharts 教程。

完整的例子请参见 ecomfe/echarts-for-weixin 项目。

暂不支持的功能

ECharts 中的绝大部分功能都支持小程序版本,因此这里仅说明不支持的功能,以及存在的问题。

以下功能尚不支持,如果有相关需求请在 issue 中向我们反馈,对于反馈人数多的需求将优先支持:

  • Tooltip
  • 图片
  • 多个 zlevel 分层

此外,目前还有一些 bug 尚未修复,部分需要小程序团队配合上线支持,但不影响基本的使用。已知的 bug 包括:

  • 安卓平台:transform 的问题(会影响关系图边两端的标记位置、旭日图文字位置等)
  • iOS 平台:半透明略有变深的问题
  • iOS 平台:渐变色出现在定义区域之外的地方

如有其它问题,也欢迎在 issue 中向我们反馈,谢谢!

收藏

19 个评论

  • 是小白啊
    是小白啊
    2018-05-11

    除了一个cover-view的解决层级问题。而且cover-view的bug很多,希望官方能尽快解决

    2018-05-11
    赞同 8
    回复
  • 峰 💋 娜
    峰 💋 娜
    2018-04-14

    很卡顿

    2018-04-14
    赞同 3
    回复
  • 🌤 ོ
    🌤 ོ
    2018-04-10

    弱弱的问下,现在小程序组件分享只能通过这种方式?人肉把组件从其他项目拷贝到自己项目?小程序没有组件托管功能?

    2018-04-10
    赞同 2
    回复
  • 东施笑贫
    东施笑贫
    2019-05-30

    环形图在安卓版的微信里面中间的空白为什么会出现颜色啊,在ios就是好的

    2019-05-30
    赞同 1
    回复 2
    • Zanyar
      Zanyar
      2019-11-09
      我这几天做 也遇到了,后来解决了吗
      2019-11-09
      回复
    • 马甲线ing
      马甲线ing
      2019-11-15
      我也遇到了,后来项目做了降级,ios用环形图,安卓用饼图~
      echarts-for-weixin 的项目已经很久没有更新过了~
      2019-11-15
      回复
  • 厉业崧
    厉业崧
    2018-03-23

    正有需要,很赞

    2018-03-23
    赞同 1
    回复
  • zven允聪
    zven允聪
    2018-02-28

    正好有需要。感谢!

    2018-02-28
    赞同 1
    回复
  • 小祥哥
    小祥哥
    2023-05-06

    scroll-view标签下滚动页面,图标抖动有什么解决办法吗?

    2023-05-06
    赞同
    回复
  • 孟婆丶倒了我的汤
    孟婆丶倒了我的汤
    2022-10-09

    你跟我说实话,是不是时至今日,还有很多功能并没有集成的很好,比如说tooltip的formatter

    2022-10-09
    赞同
    回复 1
    • 孟婆丶倒了我的汤
      孟婆丶倒了我的汤
      2022-10-09
      tooltip自定义formatter的时候,return空字符串,页面上会出现一个黑点,这个怎么解决
      2022-10-09
      回复
  • 千战
    千战
    2022-03-22

    提示:建议使用新 canvas 2d 接口提升渲染性能。。。图显示不出来啊

    2022-03-22
    赞同
    回复
  • Vampire👻
    Vampire👻
    2020-07-17

    一堆bug 太难了0.0

    2020-07-17
    赞同
    回复

正在加载...

登录 后发表内容