关于Echarts图标的tooltip配置中的formatter

本文详细介绍了如何在ECharts图表中使用formatter进行数据格式转换,包括字符串模板和自定义函数的用法,以及在不同图表类型中的数据表示。作者提供了实例代码,展示了如何针对折线图、柱状图和地图等进行格式化处理。
摘要由CSDN通过智能技术生成

使用tooltip的formatter进行格式化,格式化前效果如上图,一个是数字,一个是xxx万,不符合设计,需要统一,期望效果是这样

需要先了解formatter

格式化的类型有两种,一是字符串模板,二是自定义模板


字符串模板:

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

  • 折线(区域)图、柱状(条形)图、K线图 : {a}(系列名称),{b}(类目值),{c}(数值), {d}(无)
  • 散点图(气泡)图 : {a}(系列名称),{b}(数据名称),{c}(数值数组), {d}(无)
  • 地图 : {a}(系列名称),{b}(区域名称),{c}(合并数值), {d}(无)
  • 饼图、仪表盘、漏斗图: {a}(系列名称),{b}(数据项名称),{c}(数值), {d}(百分比)


示例

formatter: '{b0}: {c0}'

自定义函数(回调函数):

回调函数格式:

(params: Object|Array, ticket: string, callback: (ticket: string, html: string)) => string


这里字符串模板不太方便实现,所以使用自定义模板


自定义函数的第一个参数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,
 }

在 trigger 为 ‘axis’ 的时候,或者 tooltip 被 axisPointer 触发的时候,params 是多个系列的数据数组

{
    componentType: 'series',
    // 系列类型
    seriesType: string,
    // 系列在传入的 option.series 中的 index
    seriesIndex: number,
    // 系列名称
    seriesName: string,
    // 数据名,类目名
    name: string,
    // 数据在传入的 data 数组中的 index
    dataIndex: number,
    // 传入的原始数据项
    data: Object,
    // 传入的数据值。在多数系列下它和 data 相同。在一些系列下是 data 中的分量(如 map、radar 中)
    value: number|Array|Object,
    // 坐标轴 encode 映射信息,
    // key 为坐标轴(如 'x' 'y' 'radius' 'angle' 等)
    // value 必然为数组,不会为 null/undefied,表示 dimension index 。
    // 其内容如:
    // {
    //     x: [2] // dimension index 为 2 的数据映射到 x 轴
    //     y: [0] // dimension index 为 0 的数据映射到 y 轴
    // }
    encode: Object,
    // 维度名列表
    dimensionNames: Array<String>,
    // 数据的维度 index,如 0 或 1 或 2 ...
    // 仅在雷达图中使用。
    dimensionIndex: number,
    // 数据图形的颜色
    color: string,

}

第二个参数 ticket 是异步回调标识,配合第三个参数 callback 使用。

第三个参数 callback 是异步回调.

在提示框浮层内容是异步获取的时候,可以通过 callback 传入上述的 ticket 和 html 更新提示框浮层内容。

示例

formatter: function (params, ticket, callback) {
    $.get('detail?name=' + params.name, function (content) {
        callback(ticket, toHTML(content));
    });
    return 'Loading';
}




最后是实现代码

formatNumber是自己写的通用格式化函数

option = {
        title: {
            text: '',
        },
        color: '',
        tooltip: {
            trigger: 'axis',//触发类型 [item,axis,none] item"数据项图形触发,主要在散点图,饼图等无类目轴的图表。'axis'坐标轴触发,主要在柱状图,折线图等会使用类目轴的图表
            axisPointer: {
                type: 'cross',//line 直线指示器 shadow 阴影指示器 none 无指示器 cross 十字准星指示器
            },
            formatter: function (params: any) {
                let result = params[0].name + '<br>' // 获取横轴对应的数据作为提示信息的标题
                params.forEach(function (item: any) {
                    if (item.seriesType === 'line') {
                        result += item.marker + ' ' + item.seriesName + ': ' + formatNumber(item.value) + '<br>' // 对折线图数据进行格式化
                    } else if (item.seriesType === 'bar') {
                        result += item.marker + ' ' + item.seriesName + ': ' + formatNumber(item.value) + ' <br>' // 对柱状图数据进行格式化
                    }
                })
                return result
            },
        },
        grid: {},
        legend: {data: [a,b]},
        xAxis: [],
        yAxis: [],
        series: [],
    }

在 Vue 使用 Echarts 时,如果遇到tooltip不更新的问题,可以检查以下几个方面: 1. 确认数据已经更新 首先要确定数据已经更新,这可以通过打印或者在页面上显示数据进行确认。 2. 确认tooltip.formatter的params参数 在tooltip.formatter,params参数是一个数组,它包含了当前图表的数据。如果params没有更新,则可能是因为params没有正确的绑定到Vue的数据上。可以使用Vue的watch属性来监听数据的变化,然后手动更新params参数。 3. 使用Vue的ref属性 使用Vue的ref属性来获取图表实例,然后通过实例来更新tooltip.formatter的params参数。在mounted生命周期钩子函数,可以获取到实例,然后在数据更新之后,手动调用实例的setOption方法来更新图表。 ``` <template> <div ref="chart" style="width: 100%; height: 100%;"></div> </template> <script> import echarts from 'echarts'; export default { name: 'EchartsDemo', data() { return { chartData: [], }; }, mounted() { this.chart = echarts.init(this.$refs.chart); this.chart.setOption(this.getOption()); }, methods: { getOption() { return { tooltip: { trigger: 'axis', formatter: (params) => { return `x:${params[0].value[0]} y:${params[0].value[1]}`; }, }, series: [ { type: 'scatter', data: this.chartData, }, ], }; }, updateChartData() { // 更新数据 this.chartData = [ [1,2], [2,3], [3,4] ]; // 手动更新tooltip.formatter的params参数 this.chart.setOption({ tooltip: { formatter: (params) => { return `x:${params[0].value[0]} y:${params[0].value[1]}`; }, }, series: [ { type: 'scatter', data: this.chartData, }, ], }); }, }, }; </script> ``` 以上是一些可能的解决方案,如果还不能解决问题,可以提供更多的信息以便进一步排查。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值