配置项如下
let chartData =[
{"value": 600,"name": "单位1"},
{"value":500,"name": "单位2"},
{"value":400,"name": "单位3"},
{"value": 300,"name": "单位4"},
{"value": 200,"name": "单位5"},
];
let icon1 = '';
let icon2='';
let colorList =[
['#9ffafa', '#9ffafa', '#9ffafa', '#0093ff'],
['#f4ceb9', '#f4ceb9', '#f4ceb9', '#0093ff'],
['#b2b4ff', '#b2b4ff', '#b2b4ff', '#0093ff']
]
option = {
backgroundColor:'#003a82',
tooltip: {
show:false,
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
legend: {
show: false
},
grid: {
left: '50',
right:'3%',
top: '6%',
bottom:0,
containLabel:true
},
xAxis: {
show: false,
type: 'value'
},
yAxis: [
{
type: 'category',
inverse: true,
axisLine: {
show: false
},
axisTick: {
show: false
},
axisPointer: {
label: {
show: true,
margin: 5
}
},
data:chartData.map(item => item.name),
axisLabel: {
show: false,
inside: false,
fontSize: 14,
color: '#88caef',
},
},
{
type: 'category',
inverse: true,
axisTick: 'none',
axisLine: 'none',
show: true,
data: chartData.map(item => item.value),
axisLabel: {
show:true,
fontSize: 14,
color: '#88caef',
formatter:'{value}'
}
}
],
series: [
{
z: 2,
name: 'value',
type: 'bar',
barWidth: 5,
zlevel: 1,
data: chartData.map((item, i) => {
let itemStyle = {
color: i > 3 ? colorList[0][3] : colorList[0][i]
}
return {
value: item.value,
itemStyle: itemStyle
};
}),
label: {
normal: {
color: '#b3ccf8',
show: true,
position: [-30, '-15'],
textStyle: {
fontSize: 12,
color: '#88caef',
},
rich: {
a1: {
color: '#fff',
fontSize: 16,
fontWeight:600,
backgroundColor: {
image: icon1
},
width: 20,
height: 10,
align: 'center',
borderRadius: 2
},
a2: {
color: '#fff',
fontSize: 16,
fontWeight:600,
backgroundColor: {
image: icon1
},
width: 20,
height: 10,
align: 'center',
borderRadius: 2
},
a3: {
color: '#fff',
fontSize: 16,
fontWeight:600,
backgroundColor: {
image: icon1
},
width: 20,
height: 10,
align: 'center',
borderRadius: 2
},
b: {
color: '#fff',
fontSize: 16,
fontWeight:600,
backgroundColor: {
image:icon2
},
width: 20,
height: 10,
align: 'center',
borderRadius: 2
}
},
formatter: (a,b)=> {
var index = chartData.map(item => item.name).indexOf(a.name) ;
index = index + 1;
if (index - 1 < 3) {
return [
'{a' + index + '|' + index + '}' + ' ' + a.name
].join('\n')
} else {
return [
'{b|' + index + '}' + ' ' + a.name
].join('\n')
}
}
}
},
},
{
name: '总量',
type: 'bar',
barWidth: 5,
barGap: '-100%',
itemStyle: {
normal: {
color: 'rgba(32, 48, 85, 0.55)'
}
},
data: (new Array(chartData.length)).fill(chartData[0].value+50)
}
]
};