echarts自定义tooltip中的内容

原本的默认样式长这样:

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

默认代码是这样的:

tooltip: {
    trigger: 'axis',
    axisPointer: {            // 坐标轴指示器,坐标轴触发有效
        type: 'cross',        // 默认为直线,可选为:'line' | 'shadow' 'cross'
                        
    },
    confine:true, // 限制tooltip在图标区域内显示                
},

但我需要的是这样的:

代码如下:

需要加一个formatter函数


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">'; // 创建一个中心对齐的容器
        content += '<table style="border-bottom:1px solid #COCOCO">';
    
        content += '<tr><td>${params[0].name?.split(' ')[1][1]}</td></p>'; // 显示时间戳
        content += '<td style="text-indent:5px">平均</td>';
        content += '<td style="text-indent:5px">峰值</td>';
        content += '<td style="text-indent:5px">最高</td></tr>';

        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>';
        content += '<td style="text-indent:5px">${value.toFixed(2)}</td>'; // 格式化为百分比
        if (seriesName === "CPU占用率") {
            content += '<td style="text-indent:5px">${dataRow.cpu_total_grad_list[param.dataIndex]}</td>'; // 格式化为百分比
            content += '<td style="text-indent:5px">${dataRow.cpu_total_max_list[param.dataIndex]}</td></tr>';
        } else if (seriesName === "sys占用率") {
            content += '<td style="text-indent:5px">${dataRow.cpu_sys_grad_list[param.dataIndex]}</td>';
            content += '<td style="text-indent:5px">${dataRow.cpu_sys_max_list[param.dataIndex]}</td></tr>';
        } else if (seriesName === "用户占用率") {
            content += '<td style="text-indent:5px">${dataRow.cpu_user_grad_list[param.dataIndex]}</td>';
            content += '<td style="text-indent:5px">${dataRow.cpu_user_max_list[param.dataIndex]}</td></tr>';
        } 
    }

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

完成🦌

Echartstooltip组件可以通过formatter函数来自定义内容。根据引用\[1\]和引用\[2\]的内容,可以看出formatter函数的作用是根据传入的参数params来生成自定义tooltip内容。 在引用\[1\]中的示例中,formatter函数使用了一个for循环来遍历params对象中的属性,并返回了一个字符串作为tooltip内容。具体来说,它使用了params\[x\].name来获取x属性对应的name值,params\[x\].data.value来获取x属性对应的data的value值,params\[x\].data.data来获取x属性对应的data的data值。然后将这些值拼接成一个字符串,并在月份和总数之间添加了一个换行符。 在引用\[2\]中的示例中,formatter函数使用了params.value来获取value值,并根据value值的不同属性来生成不同的内容。具体来说,它使用了params.value\[0\]来获取value值的第一个元素,params.value\[2\]来获取value值的第三个元素,days\[params.value\[1\]\]来获取days数组中对应的元素。然后将这些值拼接成一个字符串,并使用<p>标签来分隔不同的内容。 因此,根据这两个示例,可以根据自己的需求来编写formatter函数,生成自定义tooltip内容。 #### 引用[.reference_title] - *1* [echarts自定义tooltip](https://blog.csdn.net/metooyoume/article/details/108726385)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [关于echarts自定义tooltip提示框内容](https://blog.csdn.net/guaiguaiknl/article/details/79908609)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值