echarts自定义tooltip提示框内容

时间:2022-11-02 08:19:46

echarts 是一个非常强大的图形编辑工具,对各种数据统计的图形话处理效果非常nice!由于在工作中经常会用到,在此以作总结,也算一种积累。

本文主要是对echarts的tooltip提示功能的一个总结。

tooltip的一些常用属性:

(1)提示内容对其方式:textStyle。

textStyle:{
align:'left'
},

tooltip的align的值可以有“center”、left、right,分别代表“居中对齐“、“左对齐”、“右对齐”。

(2)提示框触发方式:trigger

tooltip的trigger的值可以有'item''axis'

'item':数据项图形触发,主要在散点图,饼图等无类目轴的图表中使用。

'axis':坐标轴触发,主要在柱状图,折线图等会使用类目轴的图表中使用

(3)提示框的格式:formatter

这里主要分为两种模式:

第一种是字符串模板,这里不再赘述,请看 官方文档http://echarts.baidu.com/option.html#tooltip.formatter

第二种是自定义函数;

formatter: function (params) {
},

params 是 formatter 需要的数据集。官方解释格式如下:

 {
componentType
: 'series',
// 系列类型
seriesType
: string,
// 系列在传入的 option.series 中的 index
seriesIndex
: number,
// 系列名称
seriesName
: string,
// 数据名,类目名
name
: string,
// 数据在传入的 data 数组中的 index
dataIndex
: number,
// 传入的原始数据项
data
: Object,
// 传入的数据值
value
: number|Array,
// 数据图形的颜色
color
: string,

// 饼图的百分比
percent
: number,

}

这里主要是明白params代表的含义,可以使用alert(JSON.stringify(params));

在 trigger 为 'axis' 的时候 params 是多个系列的数据数组

如下图所示:

echarts自定义tooltip提示框内容echarts自定义tooltip提示框内容

echarts自定义tooltip提示框内容























由图可以看出params主要是对象数组,params和echarts的series是关联的。这里数组的个数取决于series的个数,当series只有一个时,params也就是只有一个对象的数组。

由parmas的结构我们可以*定义想要展示的提示数据。

例如:

formatter: function (params) {

var res='<div><p>时间:'+params[0].name+'</p></div>' 
for(var i=0;i<params.length;i++){
res+='<p>'+params[i].seriesName+':'+params[i].data+'</p>'
}
return res;
},

则显示的效果如下:

echarts自定义tooltip提示框内容echarts自定义tooltip提示框内容

echarts自定义tooltip提示框内容

这里想多说一句的是,想要知道echarts中回调函数的格式,就可以使用JSON.stringify(参数名)的形式来具体看该参数到底是数组还是对象,看它的结构有利于明白自己想要获取哪些值,这是一个很好的办法。