关于Echarts中formatter实现动态数据的方法

由于在近期工作内容中用到echarts,实现产品设计图时遇到一些小问题,比如:
设计图是这样的:
kirinlau

而Echarts的legend图例大概是这样的(注:以下demo都是随手写的):
这里写图片描述
看到echarts动态数据想到的当然是formatter了, 然后想到的当然是tooltip中的formatter啦,tooltip就是鼠标悬浮图表item的那个半透明的小框,大概长这样:
这里写图片描述
code长这样(既然能来这里,相相比大家也都知道):

tooltip : {
    trigger: 'item',
    formatter: "{a} <br/>{b} : {c} ({d}%)"
},

想着就是a,b,c,d四个参数都是echarts准备好的直接使用,结果变成这样:
这里写图片描述
【尼克杨问号脸】 WTF?
把tooltip中的formatter贴在legend中这条路行不通,查了一下文档没看到相关方法,网上看到好像说是用什么函数可以。诸如:

formatter: function (params) {
    // do some thing
}

又以为这个params是个对象什么的,里面存有各项的属性,是否可以直接使用, 但是这个params打印出来是个legend图例中的各项,对其进行操作并无什么有价值作用,于是就想到把要显示的数值赋值给formatter然后使用,首先想到的是读取series中的data数组中的对象属性,然后遍历赋值给params即可。
如下:
这里写图片描述

code :

formatter: function (params) {
   // console.log(params);
   for (var i = 0; i < option.series[0].data.length; i++) {
       if (option.series[0].data[i].name == params) {
           return params +":"+ option.series[0].data[i].value+"起";
       }
   }
}

果然可行,当然如有优解或有其他更好的方法欢迎提出交流。

ECharts 饼图的 formatter 属性可以用于渲染表格。以下是一个示例: ```javascript // 饼图数据 var data = [ { value: 335, name: '直接访问' }, { value: 310, name: '邮件营销' }, { value: 234, name: '联盟广告' }, { value: 135, name: '视频广告' }, { value: 1548, name: '搜索引擎' } ]; // 表格数据 var tableData = []; for (var i = 0; i < data.length; i++) { var item = data[i]; tableData.push({ name: item.name, value: item.value, percent: item.value / 2752 * 100 + '%' }); } // 饼图配置项 var option = { tooltip: { trigger: 'item', formatter: '{a} <br/>{b}: {c} ({d}%)' }, legend: { orient: 'vertical', left: 'left', data: ['直接访问', '邮件营销', '联盟广告', '视频广告', '搜索引擎'] }, series: [ { name: '访问来源', type: 'pie', radius: '50%', data: data, itemStyle: { emphasis: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: 'rgba(0, 0, 0, 0.5)' } }, label: { formatter: '{b}: {c} ({d}%)' } } ] }; // 渲染表格 var table = '<table>' + '<tr><th>名称</th><th>数值</th><th>百分比</th></tr>'; for (var i = 0; i < tableData.length; i++) { var item = tableData[i]; table += '<tr><td>' + item.name + '</td><td>' + item.value + '</td><td>' + item.percent + '</td></tr>'; } table += '</table>'; document.getElementById('table').innerHTML = table; // 渲染饼图 var myChart = echarts.init(document.getElementById('pie')); myChart.setOption(option); ``` 在上面的示例,我们将饼图的数据转换为表格数据,并使用字符串拼接的方式生成了一个 HTML 表格。最后,将生成的表格插入到页面的某个元素。 在 formatter ,我们使用了 `{a}`、`{b}`、`{c}` 和 `{d}` 这些占位符来获取提示框的数据。其,`{a}` 表示系列名称,`{b}` 表示数据项名称,`{c}` 表示数据项值,`{d}` 表示百分比。在饼图的 label ,我们也使用了 `{b}`、`{c}` 和 `{d}` 这些占位符来显示数据项名称、数据项值和百分比。
评论 26
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kirinlau

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值