关于Echarts柱状图点击事件的实现方法

开发过程当中,咱们常常会碰到这样的需求:在柱状图上,点击某条柱形,调用相应的方法或跳转相应的界面数组

接下来就详细介绍如何实现柱状图的点击事件,其中maChart是绘图对象spa

 

1、简单的点击事件code

myChart.on('click', function (params) { console.log(params) })

这样就能够得到每条柱形所对应的数据对象

若须要在每条柱形上添加额外的属性,好比id等等,能够在series中,经过对象去定义,其中value是柱形的值blog

seriesData: [{value: 1, id:'...'}, {value: 2, id:'...'}, ......]

这个id一样能够在上面的点击事件的params中获取到事件

注意:此方法虽实现了点击,可是只限于点击柱形中有数据的部分,而对于没有数据的区域,点击无效,以下图开发

 

 

 若要实现点击整条柱形区域都有效,以下图,请看第二个方法get

 

 

 

2、整条柱形的点击事件io

myChart.getZr().on('click', params => { let pointInPixel = [params.offsetX, params.offsetY] if (myChart.containPixel('grid', pointInPixel)) { let xIndex = myChart.convertFromPixel({ seriesIndex: 0 }, [params.offsetX, params.offsetY])[0] console.log(xIndex) } })

其中,getZr()方法能够监听到整个画布的点击事件,zIndex是被点击的柱形的indexconsole

若要实现获取id的效果,则须要拿到series的数组,再经过index拿到对应的数据对象

相关文章
相关标签/搜索