formatter(字符串模板)

​ 模板变量有 {a},{b},{c},{d},{e},分别表示系列名,数据名,数据值等,在 trigger为’axis’的时候,会有多个系列的数据,此时可以通过{a0},{a1},{a2}这种后面加索引的方式表示系列的索引,不同图表类型下的{a},{b},{c},{d}含义不一样。

​ 其中变量{a},{b},{c},{d}在不同的图表类型下代表数据含义为:

​ 1、折线(区域)图、柱状(条形)图、K线图:{a}(系列名称),{b}(类目名),{c}(数值),{d}(无)

​ 2、散点图(气泡)图:{a}(系列名称),{b}(数据名称),{c}(数值数组),{d}(无)

​ 3、地图:{a}(系列名称),{b}(区域名称),{c}(合并数值),{d}(无)

​ 4、饼图、仪表盘、漏斗图:{a}(系列名称),{b}(数据项名称),{c}(数值),{d}(百分比)

echart图的tooltip 官方一般都是:

而我们通常是需要显示额外内容的,比如这样

其中Tooltip参考写法

option = {
    title: {
        text: '折线图堆叠'
    tooltip: {
        trigger: 'axis',
        formatter: function (params, ticket, callback) {
          var htmlStr = '';
          for(var i=0;i<params.length;i++){
            var param = params[i];
            var xName = param.name;//x轴的名称
            var seriesName = param.seriesName;//图例名称
            var value = param.value;//y轴值
            var color = param.color;//图例颜色
            if(i===0){
              htmlStr += xName + '<br/>';//x轴的名称
            htmlStr +='<div>';
            // 具体显示的数据【字段名称:seriesName,值:value】
            // 这里判断一下name,如果是我们需要特殊处理的,就处理
            if(seriesName === '联盟广告'){
                // 前面一条线,后面一条线【具体样式自己写】
                htmlStr += '<div style="border: 1px solid #FFEB3B"></div>';
                htmlStr += 'xxxx联盟广告:' + value +'单位(%)';
                htmlStr += '<div style="border: 1px solid #FFEB3B"></div>';
            }else{
                // 正常显示的数据,走默认
                htmlStr += '<span style="margin-right:5px;display:inline-block;width:10px;height:10px;border-radius:5px;background-color:'+color+';"></span>';
                htmlStr += seriesName + ':' + value + 'W';
            htmlStr += '</div>';
          return htmlStr;
    legend: {
        data: ['邮件营销', '联盟广告']
    grid: {
        left: '3%',
        right: '4%',
        bottom: '3%',
        containLabel: true
    toolbox: {
        feature: {
            saveAsImage: {}
    xAxis: {
        type: 'category',
        boundaryGap: false,
        data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日']
    yAxis: {
        type: 'value'
    series: [
            name: '邮件营销',
            type: 'line',
            stack: '总量',
            data: [120, 132, 101, 134, 90, 230, 210]
            name: '联盟广告',
            type: 'line',
            stack: '总量',
            data: [220, 182, 191, 234, 290, 330, 310]

当然:如果你想拼接其他数据可以通过传入数据的index去获取键值显示

分类:
前端
标签: