echarts自定义tooltip中的内容

竹秋… 2024-10-21 09:03:01 阅读 90

原本的默认样式长这样:

也就是有几个图例,就显示几个再加上数字。

默认代码是这样的:

<code>tooltip: {

trigger: 'axis',

axisPointer: { // 坐标轴指示器,坐标轴触发有效

type: 'cross', // 默认为直线,可选为:'line' | 'shadow' 'cross'

},

confine:true, // 限制tooltip在图标区域内显示

},

但我需要的是这样的:

代码如下:

需要加一个formatter函数

<code>

tooltip: {

trigger: 'axis',

axisPointer: { // 坐标轴指示器,坐标轴触发有效

type: 'cross', // 默认为直线,可选为:'line' | 'shadow' 'cross'

},

confine:true, //限制tooltip在图表区域内显示

formatter:function(params) {

console.log(params);

let content = '<div style="text-align: left;width:250px;margin-left:20px">'; // 创建一个中心对齐的容器code>

content += '<table style="border-bottom:1px solid #COCOCO">';code>

content += '<tr><td>${params[0].name?.split(' ')[1][1]}</td></p>'; // 显示时间戳

content += '<td style="text-indent:5px">平均</td>';code>

content += '<td style="text-indent:5px">峰值</td>';code>

content += '<td style="text-indent:5px">最高</td></tr>';code>

for (let i = 0; i < params.length; i++) {

const param = params[i];

const seriesName = param.seriesName; // 获取系列名称

const value = param.data; // 获取数据值

const color = param.color; // 获取颜色

content += '<tr><td style="text-indent:5px;border-left:2px solid ${color}">${seriesName}</td>';code>

content += '<td style="text-indent:5px">${value.toFixed(2)}</td>'; // 格式化为百分比code>

if (seriesName === "CPU占用率") {

content += '<td style="text-indent:5px">${dataRow.cpu_total_grad_list[param.dataIndex]}</td>'; // 格式化为百分比code>

content += '<td style="text-indent:5px">${dataRow.cpu_total_max_list[param.dataIndex]}</td></tr>';code>

} else if (seriesName === "sys占用率") {

content += '<td style="text-indent:5px">${dataRow.cpu_sys_grad_list[param.dataIndex]}</td>';code>

content += '<td style="text-indent:5px">${dataRow.cpu_sys_max_list[param.dataIndex]}</td></tr>';code>

} else if (seriesName === "用户占用率") {

content += '<td style="text-indent:5px">${dataRow.cpu_user_grad_list[param.dataIndex]}</td>';code>

content += '<td style="text-indent:5px">${dataRow.cpu_user_max_list[param.dataIndex]}</td></tr>';code>

}

}

content += '</table>';

content += '<tr><td>最大值所在主机 ${dataRow.cpu_max_host[params[0]?.dataIndex]}</td></tr>';

return content;

}

}

完成🦌



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。