Показать сумму значений данных в верхней части гистограммы с использованием Baidu ECharts
Я создал вертикальную гистограмму с Baidu ECharts.
Можно ли показать сумму всех значений на вершине стека?
Отредактировано: я отредактировал мой пример, используя (очень хорошо объясненный) ответ от @jeffrey, но я получил Uncaught TypeError : Невозможно прочитать свойство 'forEach' с неопределенной ошибкой. Что я здесь не так делаю?
<!DOCTYPE html>
<html style="height: 100%">
<head>
<meta charset="utf-8">
</head>
<body style="height: 100%; margin: 0">
<div id="container" style="height: 100%"></div>
<script type="text/javascript" src="echarts-en.min.js"></script>
<script type="text/javascript">
var mySeries = [
{
name: 'Department 1',
type: 'bar',
stack: 'stack1',
data: [320, 302, 301, 334, 390, 330, 320]
},
{
name: 'Department 2',
type: 'bar',
stack: 'stack1',
data: [120, 132, 101, 134, 90, 230, 210]
},
{
name: 'Department 3',
type: 'bar',
stack: 'stack1',
data: [220, 182, 191, 234, 290, 330, 310]
},
{
name: 'Department 4',
type: 'bar',
stack: 'stack1',
data: [150, 212, 201, 154, 190, 330, 410]
},
{
name: 'Department 5',
type: 'bar',
stack: 'stack1',
data: [185, 120, 55, 66, 77, 88, 40],
label: {
normal: {
show: true,
position: 'top',
formatter: (params) => {
let total = 0;
this.series.forEach(serie => {
total += serie.data[params.dataIndex];
})
return total;
}
}
}
}
];
var dom = document.getElementById("container");
var myChart = echarts.init(dom);
var option = null;
option = {
tooltip : {
trigger: 'axis',
axisPointer : {
type : 'shadow'
}
},
legend: {
data: ['Department 1', 'Department 2','Department 3','Department 4','Department 5'],
},
toolbox: {
show: true,
orient: 'vertical',
left: 'right',
top: 'center',
feature: {
dataView: {show: false, readOnly: false},
magicType: {show: true, type: ['line', 'bar', 'stack', 'tiled']},
restore: {show: true},
saveAsImage: {show: true}
}
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
yAxis: {
type: 'value'
},
xAxis: {
type: 'category',
data: ["Jen\n2018", "Feb\n2018", "Mar\n2018", "Apr\n2018", "May\n2018", "Jun\n2018", "Jul\n2018"]
}
};;
myChart.setOption(option, true);
myChart.setOption({
series: mySeries
})
</script>
</body>
</html>
1 ответ
Чтобы получить индивидуальный ярлык серии, вы должны использовать средство форматирования ярлыков.
Когда вы определяете данные ряда за пределами объекта диаграммы и сопоставляете их с this
Вы можете получить доступ к данным в форматере. Важно использовать средство форматирования, чтобы исходная метка и значения не изменялись (например, всплывающие подсказки и легенды).
Сначала мы определим вашу серию. Форматер должен быть добавлен в последнюю серию. Это будет серия на вершине стека, показывая метку с общим значением:
this.mySeries = [
{
name:'Dataset 1',
type:'bar',
stack: 'Stack 1',
data: [120, 132, 101, 134, 90, 230, 210]
},
{
name:'Dataset 2',
type:'bar',
stack: 'Stack 1',
data: [220, 182, 191, 234, 290, 330, 310]
},
{
name:'Dataset 3',
type:'bar',
stack: 'Stack 1',
data: [820, 932, 901, 934, 1290, 1330, 1320],
label: {
normal: {
show: true,
position: 'top',
formatter: (params) => {
let total = 0;
this.mySeries.forEach(serie => {
total += serie.data[params.dataIndex];
})
return total;
}
}
}
}
];
Вот снова форматтер с аннотациями, чтобы вы могли понять, как это работает:
label: {
// You can choose from 'normal' (always visible )
// and 'emphasis' (only visible on stack hover)
normal: {
// Enable the label
show: true,
// Position it on top of the stack
position: 'top',
// Add a label formatter
// (params) holds all the data of the current serie and datapoint
// You can use console.log(params) to check all available values
formatter: (params) => {
let total = 0;
// Now we iterate over each of the series, and get the value of
// the current xAxis datapoint by using the serie dataIndex
this.mySeries.forEach(serie => {
total += serie.data[params.dataIndex];
})
// The return value will be shown on top of your stack
return total;
}
}
}
Теперь все, что вам нужно сделать, это сопоставить данные серии с вашим объектом диаграммы:
myChart.setOption({
series: this.mySeries
})
Пожалуйста, посмотрите этот ответ, он мне очень помог, и я немного упростил код, ничего важного. Я нашел объяснение проще. В основном вы будете использовать атрибут форматирования внутри метки с некоторыми спецификациями.
пример серии
let series = [
{
name: 'Reclamação',
data: this.relatos_tipo_y.R,
},
{
name: 'Elogio',
data: this.relatos_tipo_y.E,
},
{
name: 'Sugestão',
data: this.relatos_tipo_y.S,
},
{
name: 'Denúncia',
data: this.relatos_tipo_y.D,
},
];
функция для форматтера
genFormatter = (series) => {
return (param) => {
console.log(param);
let sum = 0;
series.forEach(item => {
sum += item.data[param.dataIndex];
});
return sum
}
};
внутри параметров диаграммы поместите это
series: series.map((item, index) => Object.assign(item, {
type: 'bar',
stack: true,
label: {
show: index === series.length - 1,
formatter: genFormatter(series),
fontSize: 20,
color: 'black',
position: 'top'
},
})),
Он очень похож на другой ответ, но мне легче понять код.