赞
踩
移动端设备中,难免会涉及到数据的可视化展示、数据统计等等,本篇主要讲解原生微信小程序中嵌入echarts
并进行动态渲染,实现数据可视化功能。
首先在GitHub
上下载echarts
包
地址:https://github.com/ecomfe/echarts-for-weixin/tree/master
下载项目
解压压缩包,将ec-canvas
文件夹放到我们的项目中
在需要使用的页面引入echarts
{
"usingComponents": {
"ec-canvas": "/ec-canvas/ec-canvas"
}
}
在页面中使用
<view class="line_chart">
<ec-canvas class="chart" id="charts" canvas-id="mychart-line" ec="{{ ec }}"></ec-canvas>
</view>
先给echarts
的父级元素设置高度
.line_chart {
width: 100%;
height: 550rpx;
background: #fff;
}
然后就可以使用了
// 引入 echarts 文件,这里路径一定要正确,就是ec-canvas -> echart.js import * as echarts from '../../../ec-canvas/echarts'; // 定义 initChart 方法 function initChart(canvas) { const chart = echarts.init(canvas, null, { height: 250, // 图表高 // width: 100 // 图标宽 }); canvas.setChart(chart); // 此为配置项。配置图表展现样式与数据 var option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [150, 230, 224, 218, 135, 147, 260], type: 'line' } ] }; chart.setOption(option); return chart; } Page({ /** * 页面的初始数据 */ data: { // 此处的ec名称与wxml结构中命名保持一致 ec: { // 使用 onInit 方法定义 onInit: initChart } }, /** * 生命周期函数--监听页面加载 */ onLoad(options) { }, })
在echarts
中,配置项与echarts
文档中的配置项相同,按照官网的配置项进行开发即可。
配置项手册:https://echarts.apache.org/zh/option.html
我们会根据业务场景,传入不同的数据进行动态渲染echarts
,那么在这里charts
实例就必须配置为全局
var chart = null; // 重要-保存chart为全局实例
// initChart必须为全局函数
function initChart(canvas) {
chart = echarts.init(canvas, null, {
height: 250,
});
canvas.setChart(chart);
return chart;
}
当你的数据变化后,重新渲染echarts
data: { ec: { onInit: initChart } }, getData() { return { // 你配置的的options数据...... }; }, getCharts() { setTimeout(() => { // 由于chart被你定义为全局,所以这里可以直接获取 // 通过setOption设置options数据,刷新图标 chart.setOption(this.getData(), true) }, 1500) }
在options
配置中添加
tooltip: {
textStyle: {
textShadowBlur: 10, // 去掉文字阴影
textShadowColor: 'transparent', // 去掉文字阴影
},
},
在真机中echarts
可能会出现分辨率低,图形模糊的情况,此时我们需要获取设备像素比给echarts
做初始化设置。
微信小程序获取设备信息:wx.getSystemInfo
function initChart(canvas) { // 获取设备像素比 const getPixelRatio = () => { let pixelRatio = 0 wx.getSystemInfo({ success: function (res) { pixelRatio = res.pixelRatio }, fail: function () { pixelRatio = 0 } }) return pixelRatio } var dpr = getPixelRatio(); // 像素比 chart = echarts.init(canvas, null, { height: 250, devicePixelRatio: dpr // 设置初始化像素比 }); canvas.setChart(chart); return chart; }
此时图表的像素就会按照设配像素比进行渲染
上面直接引入echarts
的方式是对echarts
的完全引入,体积会比较大,接近1000kb
左右,微信小程序是由分包限制的,所以我们可以根据项目需求来按需引入图标,减少echarts
体积。
官网在线订制入口:在线订制
假如你的项目中只需要一个折线图,那么这里只勾线折线图
选择你折线图应用的坐标系
选择echarts可使用的组件,这个组件就是echarts上的一些可配置项,如下图:
点击下载,系统会生成并压缩echarts文件
下载完成后,我们会获得一个echarts.min.js
文件,还记得我们之前完全引入echarts
的步骤吗,我们将echarts
的完整包都引入了项目中,也就是这张图
这里的echarts
文件大小接近1000kb
,我们要做的就是替换这个文件
把压缩好的echarts.min.js
文件复制到该文件夹中,删除echarts.js
文件,并将echarts.min.js
文件名字改为echarts.js
即可。
另外
1、你可以将echarts
封装成组件,通过observers
监听数据的变化来实现echarts
的动态渲染。
2、在渲染层面,你可以将 legend
、label
、调色盘
、 series
拆开,这样可以方便你更好的管理数据。
3、微信小程序有分包限制,在这里我做的是echarts
包的直接下载,可能会占一些体积,你可以在echarts
官网上选择在线订制,只下载你需要的图表解来减少包的体积,官网:在线订制
如果你觉得本文章不错,欢迎点赞 本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。