温州万排乡微信小程序中使用echarts

阅读 23022  ·  发布日期 2020-08-24 17:26  ·  温州优光网络科技有限公司|建站|APP小程序制作|做网站SEO推广优化
【摘要】 人在家中坐,锅从天上来。半个月前本来在家写着一个项目,还没来得及提测,领导突然一个电话,需要立刻去支援另一个项目,一打听,一个烂尾半年的项目,纵使内心不愿意,还是要去啊。因为鲁迅说过,生活就像强*,既然不能反抗,那就好好享受吧。这个项目分为PC端、用户端小程序和商家端小程序,这里主要讲讲在商家端中的某个模块,需要用到数... 【温州小程序开发,温州微信公众号,平阳做网站,平阳网站建设公司,平阳小程序商城制作,昆阳万全做网站,鳌江水头小程序,萧江腾蛟微信公众号,山门顺溪南雁海西南麂凤卧麻步怀溪网络网店服务,政采云网店管理服务】...

微信小程序中使用echarts

人在家中坐,锅从天上来。
半个月前本来在家写着一个项目,还没来得及提测,领导突然一个电话,需要立刻去支援另一个项目,一打听,一个烂尾半年的项目,纵使内心不愿意,还是要去啊。
因为鲁迅说过,生活就像强*,既然不能反抗,那就好好享受吧。
这个项目分为PC端、用户端小程序和商家端小程序,这里主要讲讲在商家端中的某个模块,需要用到数据统计图表,当时觉得有两个插件不错:
百度 echarts阿里 AntV因为之前在项目中使用echarts比较多,所以最终选择了echarts作为项目中的图表插件echarts的引入我是按照echarts官网教程来引入的,很简单,不多说。
传送门echarts中使用多个图表wxml代码如下:
js代码如下data: {
isShoweyes: true, turnoverEc: {
lazyLoad: true, }
, customerEc: {
lazyLoad: true, }
, priceEc: {
lazyLoad: true, }
, echartsData: {
}
}
, onLoad: function (options) {
this.echartsComponnet1 = this.selectComponent('
#mychart-dom-turnover'
);
this.echartsComponnet2 = this.selectComponent('
#mychart-dom-customer'
);
this.echartsComponnet3 = this.selectComponent('
#mychart-dom-price'
);
}
, getData: function () {
// .... 获取数据 for (let i = 1;
i i++) {
if (!Chart[i]) {
this.initEcharts(i);
//初始化图表 }
else {
this.setOption(i);
//更新数据 }
}
}
, initEcharts: function (i) {
this['
echartsComponnet'
+ i].init((canvas, width, height) => {
// 初始化图表 Chart[i - 1] = echarts.init(canvas, null, {
width: width, height: height }
);
this.setOption(i);
// 注意这里一定要返回 chart 实例,否则会影响事件处理等 return Chart[i - 1];
}
);
}
, setOption: function (i) {
Chart[i - 1].clear();
// 清除 Chart[i - 1].setOption(this['
getOption'
+ i]());
//获取新数据 }
, getOption1() {
let {
echartsData }
= this.data;
return {
color: ['
#0179FF'
], tooltip: {
trigger: '
axis'
, axisPointer: {
// 坐标轴指示器,坐标轴触发有效 type: '
shadow'
, // 默认为直线,可选为:
'
line'
| '
shadow'
shadowStyle: {
opacity: 0.8 }
}
, formatter: this.formatterTooltip, position: this.setTooltipPositionfunction }
, grid: {
left: 20, right: 20, bottom: 15, top: 40, containLabel: true }
, xAxis: [{
type: '
category'
, axisLine: {
lineStyle: {
color: '
#999'
, }
}
, axisLabel: {
color: '
#666'
, }
, data: echartsData.totalRecentRansactions.dates, }
], yAxis: [{
type: '
value'
, axisTick: {
show: false }
, axisLine: {
show: false, lineStyle: {
color: '
#999'
, }
}
, axisLabel: {
color: '
#666'
, fontSize: 13 }
}
], series: [{
name: '
订单总额'
, type: '
line'
, label: {
normal: {
show: true,// 是否在折线点上显示数值 position: '
inside'
}
}
, data: echartsData.totalRecentRansactions.allTotalMoney }
] }
;
}
遇到的坑 1.Tooltip支持不好 虽然官网上echarts暂时不支持Tooltip,但是经过试验,还是Tooltip还是有效果的,但是,x轴对应的坐标值并不会显示在Tooltip中,需要使用Tooltip的formatter函数,自己处理需要展示的数据,代码如下:
// 格式化Tooltip formatterTooltip(param) {
return "日期:
" + param[0].name + " " + param[0].seriesName + ": " + param[0].data }
, 2.当点击靠近屏幕右侧或者底部的item项时,Tooltip会溢出边界,解决办法:
给Tooltip的position函数返回一个根据点击位置计算的坐标点,(也可以给一个固定的位置,但是体验不好) // 更改Tooltip的位置,处理边界超出的情况 setTooltipPositionfunction(point, params, dom, rect, size) {
//其中point为当前鼠标的位置,size中有两个属性:
viewSize和contentSize,分别为外层div和tooltip提示框的大小 // 更改提示框的显示位置 let x = point[0];
// let y = point[1];
// size: 包括 dom 的尺寸和 echarts 容器的当前尺寸,例如:
{
contentSize: [width, height], viewSize: [width, height]}
let boxWidth = size.contentSize[0];
// let boxHeight = size.contentSize[1];
// size里面此处获取不到dom的高度,值为NAN,所以下面指定了一个固定值 let boxHeight = 50;
let posX = 0;
//x坐标位置 let posY = 0;
//y坐标位置 if (x //左边放不开 posX = 5;
}
else {
//左边放的下 posX = x - boxWidth;
}
if (y //上边放不开 posY = 5;
}
else {
//上边放得下 posY = y - boxHeight;
}
return [posX, posY];
}
,上面需要注意的是,获取dom的高度,官方上说的是可以从position回调函数的size参数中获取到dom的高度,但是我打印出来却是NAN。
打印出来结果:
后来发现参数params中outerWidth的值和参数size中contentSize的宽度值相同,所以果断取参数params中的outerHeight作为dom的高度,最后运行的效果确实没有问题。
3.左右滑动柱状图时,柱状图画板会变空白,点一下空白又会出现柱状图,而且这个问题只有在柱状图上出现!刚开始以为是自己代码的问题,后来自己检查了几遍,确实没什么问题,然后扫码体验了官方的小程序demo,发现也有这个问题,顿时只想对它口吐芬芳。
既然是官方代码自身的问题,于是去看了下源码,如下:
官方代码给画布绑定一个bindtouchmove事件touchMove(e) {
if (this.chart && e.touches.length > 0) {
var touch = e.touches[0];
var handler = this.chart.getZr().handler;
handler.dispatch('
mousemove'
, {
zrX: touch.x, zrY: touch.y }
);
handler.processGesture(wrapTouch(e), '
change'
);
}
}
,这里面又去调用了echarts.js中的方法,最后想了一个粗暴的解决办法:
删掉源码中的bindtouchmove事件完美解决,哈哈或或红红火火恍恍惚惚~~~以上就是我在小程序中使用echarts遇到的坑,希望能帮到后来踩坑的人。
最终效果图片Demo源码点 这 里推荐教程:
《JS教程》以上就是微信小程序中使用echarts的详细内容,更多请关注php中文网其它相关文章!
微信
分享相关标签:
微信小程序 echarts本文转载于:
CSDN,如有侵犯,请联系a@php.cn删除
上一篇:
如何推广小程序业务?
下一篇:
微信小程序 绝对路径 require相关文章相关视频学习微信小程序如何使用echarts图表微信小程序如何注销释放名额Proxy 对象的了解及学习怎么看小程序版本号微信小程序中使用echarts数据表的更新/删除/查询操作数据表的连接与新增操作2数据表的连接与新增操作1数组常用函数-3 [温州做小程序]