横向排名柱状图

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            // 修改自https://www.isqqw.com/add?from=35428
const dataSource = [
   {
      value: '8',
      name: '千金',
   },
   {
      value: '1',
      name: '南浔',
   },
   {
      value: '2',
      name: '双林',
   },
   {
      value: '3',
      name: '和孚',
   },
   {
      value: '3',
      name: '善琏',
   },
   {
      value: '1',
      name: '开发区',
   },
   {
      value: '6',
      name: '石淙',
   },
   {
      value: '3',
      name: '练市',
   },
   {
      value: '5',
      name: '菱湖',
   },
];

const img3 =
   '';
const img2 = '';
const img1 = '';

option = {
   backgroundColor: 'rgba(5, 62, 72, 1)',
   grid: [
      {
         left: 10,
         top: 10,
         right: 10,
         bottom: 10,
         containLabel: true,
      },
   ],
   xAxis: [
      {
         gridIndex: 0,
         type: 'value',
         axisLabel: { show: false },
         axisLine: { show: false },
         splitLine: { show: false },
         axisTick: { show: false },
      },
      {
         gridIndex: 0,
         type: 'value',
         max: 100,
         axisLabel: { show: false },
         axisLine: { show: false },
         splitLine: { show: false },
         axisTick: { show: false },
      },
   ],
   yAxis: [
      {
         gridIndex: 0,
         type: 'category',
         inverse: true,
         position: 'left',
         data: dataSource.map((item) => item.name),
         axisTick: { show: false },
         axisLine: { show: false },
         splitLine: { show: false },
         axisLabel: {
            width: 80,
            padding: [0, 0, 0, -80],
            align: 'left',
            formatter: (name, index) => {
               const id = index + 1;
               if (id < 4) {
                  return `{icon${id}|}`;
               } else {
                  return `{count|${id}}`;
               }
            },
            rich: {
               icon1: {
                  width: 35,
                  height: 15,
                  align: 'center',
                  backgroundColor: {
                     image: img1,
                  },
               },
               icon2: {
                  width: 35,
                  height: 15,
                  align: 'center',
                  backgroundColor: {
                     image: img2,
                  },
               },
               icon3: {
                  width: 35,
                  height: 15,
                  align: 'center',
                  backgroundColor: {
                     image: img3,
                  },
               },
               count: {
                  padding: [0, 0, 0, 0],
                  width: 35,
                  height: 15,
                  color: '#A4E8E8',
                  align: 'center',
                  fontSize: 15,
                  fontFamily: 'DIN',
                  fontWeight: 500,
                  fontStyle: 'italic',
               },
               name: {
                  width: 80,
                  fontSize: 15,
                  align: 'left',
                  color: '#fff',
                  fontFamily: 'Source Han Sans CN',
                  fontWeight: 500,
               },
            },
         },
      },
      {
         gridIndex: 0,
         type: 'category',
         inverse: true,
         data: dataSource.map((item) => item.name),
         axisTick: { show: false },
         axisLine: { show: false },
         splitLine: { show: false },
         position: 'left',
         axisLabel: {
            width: 80,
            padding: [0, 0, 40, 0],
            align: 'left',
            formatter: (name, index) => {
               return `{value|${name}}`;
            },
            rich: {
               value: {
                  color: '#fff',
                  fontSize: 14,
                  fontWeight: 500,
               },
            },
         },
      },
      {
         gridIndex: 0,
         type: 'category',
         position: 'right',
         inverse: true,
         margin: 20,
         data: dataSource.map((item) => item.name),
         axisTick: { show: false },
         axisLine: { show: false },
         splitLine: { show: false },
         axisLabel: {
            align: 'right',
            padding: [0, 0, 50, -40],
            formatter: (_, index) => {
               return `{value|${dataSource[index].value}.0%}`;
            },
            rich: {
               value: {
                  color: '#fff',
                  fontSize: 14,
                  fontWeight: 500,
               },
            },
         },
      },
   ],
   series: [
      {
         type: 'bar',
         xAxisIndex: 0,
         yAxisIndex: 0,
         barWidth: 10,
         data: dataSource.map((item) => item.value),
         silent: true,
         itemStyle: {
            emphasis: {
               barBorderRadius: [0, 20, 20, 0],
            },
            normal: {
               barBorderRadius: [0, 20, 20, 0],
               color: new echarts.graphic.LinearGradient(
                  0,
                  0,
                  1,
                  0,
                  [
                     {
                        offset: 0,
                        color: 'rgba(0, 255, 150, 0)', // 0% 处的颜色
                     },
                     {
                        offset: 1,
                        color: 'rgba(0, 255, 150, 1)', // 100% 处的颜色
                     },
                  ],
                  false
               ),
            },
         },
      },
      {
         type: 'pictorialBar',
         data: dataSource.map((item) => item.value),
         xAxisIndex: 0,
         yAxisIndex: 0,
         symbol: 'circle',
         symbolRotate: null,
         symbolSize: [10, 10],
         symbolPosition: 'end',
         symbolOffset: [0, 0],
         itemStyle: {
            color: 'white',
            shadowColor: 'rgba(115, 243, 255, 0.2)',
            shadowBlur: 10,
         },
      },
      {
         name: '背景',
         type: 'bar',
         barWidth: 10,
         barGap: '-100%',
         data: [10, 10, 10, 10, 10, 10, 10, 10, 10],
         itemStyle: {
            normal: {
               color: 'rgba(131, 132, 132, 0.1)',
               barBorderRadius: [30, 30, 30, 30],
            },
         },
      },
   ],
};