const base64Img = { top1: '', top2: '', top3: '' } const closingbase64Img = { top1: '', top2: '', top3: '', top4: '' } var index = 0 var result = [ { name: '基地1', value: 58 }, { name: '基地2', value: 53 }, { name: '基地3', value: 35 }, { name: '基地4', value: 30 }, ] const COLORS = ['#FFBF23', '#05F07D', '#01FCED', '#01FCED'] option = { tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器配置项。 type: 'none', // 'line' 直线指示器 'shadow' 阴影指示器 'none' 无指示器 'cross' 十字准星指示器。 axis: 'auto', // 指示器的坐标轴。 snap: true // 坐标轴指示器是否自动吸附到点上 }, renderMode: 'html', // 浮层的渲染模式,默认以 'html 即额外的 DOM 节点展示 tooltip; backgroundColor: 'rgba(50,50,50,0.7)', // 提示框浮层的背景颜色。 borderColor: '#333', // 提示框浮层的边框颜色。 borderWidth: 0, // 提示框浮层的边框宽。 padding: 5, // 提示框浮层内边距, textStyle: { // 提示框浮层的文本样式。 color: '#fff', fontStyle: 'normal', fontWeight: 'normal', fontFamily: 'sans-serif', fontSize: 12 }, extraCssText: 'box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);' // 额外附加到浮层的 css 样式 }, grid: { left: 74, top: 6, bottom: 0, right: 46 }, xAxis: { type: 'value', boundaryGap: [0, 0.01], // inverse: true, axisLine: { show: false // 隐藏y轴 }, axisTick: { show: false // 刻度线 }, axisLabel: { show: false // 隐藏刻度值 }, splitLine: { show: false // 不显示网格线 } }, yAxis: [ { type: 'category', data: result.map((item) => item.value), inverse: true, position: 'right', axisTick: { show: false // 刻度线 }, axisLine: { show: false // 隐藏y轴 }, axisLabel: { formatter: '{value}%', textStyle: { color: '#01FCED', fontSize: '10' } } }, { type: 'category', inverse: true, axisTick: 'none', axisLine: 'none', show: true, axisLabel: { textStyle: { color: function (param, index) { const color = ['#FFBF23', '#05F07D', '#01FCED', '#01FCED'] return color[index] }, fontSize: '12' }, // formatter: function (params, i) { // return `{img${i}|}` + params // }, formatter: function (params) { if (index === result.length) { index = 0 } index++ if (index - 1 < 4) { return ['{a' + index + '|' + '}' + ' ' + params].join('\n') } else { return ['{b|' + index + '}' + ' ' + params].join('\n') } }, rich: { a1: { backgroundColor: { image: closingbase64Img.top1 }, height: 22, width: 22, align: 'center' }, a2: { backgroundColor: { image: closingbase64Img.top2 }, width: 22, height: 22, align: 'center' }, a3: { backgroundColor: { image: closingbase64Img.top3 }, width: 22, height: 22, align: 'center' }, a4: { backgroundColor: { image: closingbase64Img.top4 }, width: 22, height: 22, align: 'center' }, b: { color: '#01FCED', width: 22, height: 22, align: 'center' } }, align: 'left', padding: [0, 0, 0, -60], show: true }, data: result.map((item) => item.name) } ], series: [ { name: '', type: 'bar', barWidth: 10, data: result.map((item) => item.value), itemStyle: { normal: { color: (item) => { return COLORS[item.dataIndex] }, barBorderRadius: [15, 15, 15, 15] } } } ] }