const nullData = '' // 暂无数据配置 function setNulldata(data = [], top = 330) { return [ { type: 'image', z: 666, invisible: data.length > 0, // 有数据就隐藏 style: { image: nullData, width: 100, shadowBlur: 0, shadowColor: '#000', shadowOffsetX: '1', shadowOffsetY: '1', }, left: 'center', top: top, }, { type: 'text', left: 'center', z: 666, top: top + 80, silent: true, invisible: data.length > 0, // 有数据就隐藏 style: { fill: '#9d9d9d', fontWeight: 'bold', text: '暂无数据', fontFamily: 'Microsoft YaHei', fontSize: '20px', }, }, ]; } // x轴配置,若无数据时不显示 function xAxisStyle(data = []) { return { type: 'category', show: data.length > 0, axisLine: { lineStyle: { color: 'rgba(255, 255, 255, 0.4)', }, }, splitLine: { show: false, lineStyle: { color: 'rgba(255, 255, 255, 0.15)', }, }, axisTick: { show: false, }, splitArea: { show: false, }, axisLabel: { interval: 0, color: '#89BAE5', fontSize: 14, }, }; } // y轴配置,若无数据时不显示 function yAxisStyle(data = []) { return { type: 'value', show: data.length > 0, axisLine: { lineStyle: { color: 'rgba(255, 255, 255, 0.4)', }, }, splitLine: { lineStyle: { type: 'dashed', color: 'rgba(255, 255, 255, 0.1)', }, }, axisTick: { show: false, }, axisLabel: { interval: 0, color: '#89BAE5', fontSize: 14, fontFamily: 'DINPro-Medium', }, splitArea: { show: false, }, }; } const tooltipStyle = { trigger: 'axis', backgroundColor: 'rgba(31, 46, 59, 0.6)', borderColor: 'rgba(87, 134, 173, 1)', axisPointer: { type: 'shadow', }, textStyle: { fontSize: 12, color: '#fff', }, }; const title = { textStyle: { fontSize: 16, fontFamily: 'PingFang SC', fontWeight: 400, color: 'rgba(255,255,255,.6)', }, }; const data = [ { name: 2021, value: 280 }, { name: 2020, value: 271 }, { name: 2019, value: 171 }, ] option = { backgroundColor: 'rgba(0,0,0,0.85)', color: ['#12B3FE', '#28D7E6'], title: { text: '标题', top: 110, left: 30, ...title, }, graphic: { elements: [...setNulldata(data)], }, grid: { top: 160, left: 30, bottom: 150, right: 10, containLabel: true, }, tooltip: { ...tooltipStyle, }, xAxis: { ...xAxisStyle(data), data: data.map(({ name }) => name), axisLine: { lineStyle: { color: 'rgba(255, 255, 255, 0.9)', }, }, }, yAxis: { ...yAxisStyle(data), splitNumber: 2, }, series: [ { name: '', type: 'bar', barWidth: 10, data: data.map(({ value }) => value), itemStyle: { color: { type: 'linear', x: 0, y: 0, x2: 0, y2: 1, colorStops: [ { offset: 0, color: '#12B3FE', // 0% 处的颜色 }, { offset: 1, color: 'rgba(18, 179, 254, 0)', // 100% 处的颜色 }, ], }, }, label: { show: true, position: [2, -2], color: '#fff', formatter: ' ', width: 6, height: 3, lineHeight: 3, backgroundColor: '#fff', }, }, ], }