实现效果
实现的效果就是鼠标悬浮在饼图上,提示的数据加上单位
,且单位可以不一样
代码实现——HTML、CSS部分
这一部分没什么好说的,就是引入Echarts
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8"> <title>Referer of a Website - Apache ECharts Demo</title> <style> * { margin: 0; padding: 0; } #chart-container { position: relative; height: 100vh; overflow: hidden; } </style> </head> <body> <div id="chart-container"></div> <script src="https://fastly.jsdelivr.net/npm/echarts@5.4.0/dist/echarts.min.js"></script> </body> </html>
复制
代码实现——JS部分
实现提示数据加单位的的关键代码在tooltip
上
tooltip
提示框浮层内容格式器,支持字符串模板
和回调函数
两种形式。本次案例使用的是回调函数
浅看一下回调函数格式:
支持返回 HTML 字符串或者创建的 DOM 实例。
(params: Object|Array, ticket: string, callback: (ticket: string, html: string)) => string | HTMLElement | HTMLElement[]
复制
第一个参数 params
是 formatter 需要的数据集。格式如下:
{ 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, // 饼图,漏斗图的百分比 percent: number }
复制
可能看着有点眼花缭乱,咱们实际点,打印出来看看它是个什么东西,这样你就能看出来哪些字段对应的是什么啦
(打印即console.log(params),是写在tooltip里的formatter里的,你直接打开控制台是看不到的,得让鼠标悬浮在饼图上,触发到这个提示,才能打印出来)
到这里就简单了,直接拿到我们要的是数据,用一个变量装我们想要的数据格式,把数据拼接拼接就好了(是不是很简单,单位直接给它拼接起来)记得return啊
formatter: (params) => { const str = `${params.seriesName}<br/>${params.data.name}:${params.data.value}${params.data.unit}` return str },
复制
data
里的数据格式如下给后端,让他返回这样的格式,这样就不用我们后续再去处理数据格式啦
data: [ { value: 1048, name: '大米', unit: '千克' }, { value: 735, name: '胡萝卜', unit: '吨' }, { value: 580, name: '玉米', unit: '吨'}, { value: 484, name: '莲藕' , unit: '千克' }, { value: 300, name: '排骨' , unit: '千克'}, ],
复制
JS完整代码
var dom = document.getElementById('chart-container'); var myChart = echarts.init(dom, null, { renderer: 'canvas', useDirtyRect: false }); var app = {}; var option; option = { title: { text: '美食材料', left: 'center' }, tooltip: { trigger: 'item', formatter: (params ) => { console.log(params) const str = `${params.seriesName}<br/>${params.data.name}:${params.data.value}${params.data.unit}` return str }, }, legend: { orient: 'vertical', left: 'left' }, series: [ { name: '美食', type: 'pie', radius: '50%', data: [ { value: 1048, name: '大米', unit: '千克' }, { value: 735, name: '胡萝卜', unit: '吨' }, { value: 580, name: '玉米', unit: '吨'}, { value: 484, name: '莲藕' , unit: '千克' }, { value: 300, name: '排骨' , unit: '千克'}, ], emphasis: { itemStyle: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: 'rgba(0, 0, 0, 0.5)' } } } ] }; if (option && typeof option === 'object') { myChart.setOption(option); } window.addEventListener('resize', myChart.resize);
复制
顺便也说说字符串模板形式吧,这个比较简单点,如果你需要加的单位都一样
,用这个会更简单点
模板变量有 {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: `{a}<br />{b}: {c}千克`,
复制