效果图
代码
const barData = {
xaxis: ['A类', 'B类', 'C类', 'D类', 'E类', 'F类'],
series: [
{
name: '人才层次',
data: [10, 20, 30, 40, 50, 70],
},
],
unit: '',
colorArr: [
{
start: '#94DCFF',
end: 'rgba(2,143,255,0.00)',
},
],
splitLineHide: true,
grid: {
left: '120px',
top: '20px',
right: '0px',
bottom: '75px',
containLabel: false,
},
};
let normalColor = 'rgba(236,248,255,0.70)';
let seriesData = [];
barData.series.map((item, index) => {
let markPoint = item.data.map((item, index) => {
return {
coord: [index, item],
symbolSize: [70, 6],
symbolOffset: [0, 0],
symbol:
'image://',
};
});
let series = [
{
name: item.name,
type: 'bar',
data: item.data,
barGap: 10,
barWidth: '36px',
showBackground: true,
backgroundStyle: {
color: '#142032',
},
itemStyle: {
normal: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0,
color: barData.colorArr[index].start,
},
{
offset: 1,
color: barData.colorArr[index].end,
},
],
globalCoord: false,
},
},
},
markPoint: {
data: markPoint,
},
z: 0,
},
{
// 分隔
type: 'pictorialBar',
itemStyle: {
normal: {
color: '#142032',
},
},
symbolRepeat: 'fixed',
symbolMargin: 12,
symbol: 'rect',
symbolClip: true,
symbolSize: [36, 2],
data: item.data,
z: 1,
},
{
// 分隔
type: 'pictorialBar',
symbol:
'image://',
symbolPosition: 'start',
symbolSize: [79, 9],
symbolOffset: [0, 15],
data: item.data,
z: 1,
},
];
seriesData = [...seriesData, ...series];
});
option = {
backgroundColor: "#0B1321",
grid: barData.grid,
tooltip: {
textStyle: {
fontSize: 48,
},
trigger: 'axis',
formatter: function (params) {
let str = '';
for (let i = 0; i < params.length - 2; i++) {
if ((!!params[i].value || params[i].value === 0) && params[i].axisValue !== '') {
str += params[i].axisValue + ': ' + params[i].value + '人<br/>';
} else if (params[i].axisValue !== '') {
str += params[i].axisValue + ': ' + '无数据' + '<br/>';
}
}
return str;
},
},
xAxis: [
{
type: 'category',
data: barData.xaxis,
axisPointer: {
type: 'shadow',
},
axisLabel: {
interval: 0,
margin: 25,
formatter: (value) => {
return `{a|${value}}`;
},
width: 100,
height: 56,
align: 'center',
backgroundColor: '#142032',
rich: {
a: {
fontFamily: 'MicrosoftYaHei',
color: normalColor,
fontSize: 36,
lineHeight: 58,
},
},
},
axisLine: {
show: false,
},
axisTick: {
show: false,
},
splitLine: {
show: false,
},
},
{
type: 'category',
show: true,
axisPointer: {
show: false,
},
axisLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
interval: 0,
margin: 5,
formatter: (value) => {
return `{a|}`;
},
width: 72,
height: 9,
align: 'center',
backgroundColor: {
image:
'',
},
rich: {
a: {
fontFamily: 'DINAlternate-Bold',
color: normalColor,
fontSize: 36,
lineHeight: 58,
},
},
},
data: barData.xaxis,
},
],
yAxis: [
{
type: 'value',
name: '',
splitNumber: 3,
nameTextStyle: {
fontFamily: 'PingFangSC-Regular',
color: normalColor,
fontSize: 36,
align: 'right',
padding: barData.namePadding,
},
axisLabel: {
formatter: '{value}',
align: 'right',
textStyle: {
fontFamily: 'PingFangSC-Regular',
color: normalColor,
fontSize: 36,
},
},
axisLine: {
show: true,
lineStyle: {
type: 'solid',
width: 3,
color: '#043147',
},
},
axisTick: {
show: true,
inside: true,
lineStyle: {
type: 'solid',
width: 3,
color: '#043147',
},
},
splitLine: {
show: barData.splitLineHide ? false : true,
lineStyle: {
type: 'dashed',
width: 3,
color: '#093D5D',
},
},
},
],
series: seriesData,
};