排行柱状图

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            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]
            }
         }
      }
   ]
}