【移动应用开发技术】微信小程序中如何使用echarts模块_第1页
【移动应用开发技术】微信小程序中如何使用echarts模块_第2页
【移动应用开发技术】微信小程序中如何使用echarts模块_第3页
【移动应用开发技术】微信小程序中如何使用echarts模块_第4页
【移动应用开发技术】微信小程序中如何使用echarts模块_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

【移动应用开发技术】微信小程序中如何使用echarts模块

这篇文章主要介绍微信小程序中如何使用echarts模块,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!项目分为PC端、用户端小程序和商家端小程序,这里主要讲讲在商家端中的某个模块,需要用到数据统计图表,当时觉得有两个插件不错:百度echarts阿里AntV因为之前在项目中使用echarts比较多,所以最终选择了echarts作为项目中的图表插件echarts的引入我是按照echarts官网教程来引入的,很简单,不多说。传送门echarts中使用多个图表wxml代码如下:<!--图表1--><view

class="echarts-container"

hidden="{{!isShoweyes

||

!echartsData.totalRecentRansactions.allTotalMoney}}">

<ec-canvas

id="mychart-dom-turnover"

canvas-id="mychart-turnover"

ec="{{

turnoverEc

}}"></ec-canvas></view><!--图表2--><view

class="echarts-container"

hidden="{{!isShoweyes

||

!echartsData.shopNewCustomerRespVo.allNewCustomer}}">

<ec-canvas

id="mychart-dom-customer"

canvas-id="mychart-customer"

ec="{{

customerEc

}}"></ec-canvas></view><!--图表3--><view

class="echarts-container"

hidden="{{!isShoweyes

||

!echartsData.customerOrderAverageRespVo.customerAverage}}">

<ec-canvas

id="mychart-dom-price"

canvas-id="mychart-price"

ec="{{

priceEc

}}"></ec-canvas></view>js代码如下<!--通过lazyLoad设置图表懒加载-->data:

{

isShoweyes:

true,

turnoverEc:

{

lazyLoad:

true,

},

customerEc:

{

lazyLoad:

true,

},

priceEc:

{

lazyLoad:

true,

},

echartsData:

{}

},

<!--页面加载时创建对应的canvas面板-->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

<

4;

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

+

"\n"

+

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

<

boxWidth)

{//左边放不开

posX

=

5;

}

else

{//左边放的下

posX

=

x

-

boxWidth;

}

if

(y

<

boxHeight)

{//上边放不开

posY

=

5;

}

else

{//上边放得下

posY

=

y

-

boxHeight;

}

return

[posX,

posY];

},上面需要注意的是,获取dom的高度,官方上说的是可以从position回调函数的size参数中获取到dom的高度,但是我打印出来却是NAN。打印出来结果:后来发现参数params中outerWidth的值和参数size中contentSize的宽度值相同,所以果断取参数params中的outerHeight作为dom的高度,最后运行的效果确实没有问题。3.左右滑动柱状图时,柱状图画板会变空白,点一下空白又会出现柱状图,而且这个问题只有在柱状图上出现!刚开始以为是自己代码的问题,后来自己检查了几遍,确实没什么问题,然后扫码体验了官方的小程序demo,发现也有这个问题,顿时只想对它口吐芬芳。既然是官方代码自身的问题,于是去看了下源码,如下:<canvas

class="ec-canvas"

canvas-id="{{

canvasId

}}"

bindinit="init"

bindtouchstart="{{

ec.disableTouch

?

''

:

'touchStart'

}}"

bindtouchmove="{{

ec.disableTouch

?

''

:

'touchMove'

}}"

bindtouchend="{{

ec.disableTouch

?

''

:

'touchEnd'

}}"></canvas>官方代码给画布绑定一个bindtouchmove事件touchMove(e)

{

if

(this.chart

&&

e.touches.length

>

0)

{

var

touch

=

e.touches[0];

var

handler

=

this.chart.getZr().handler;

handler.dispatch('mousemove'

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论