基地销售排行

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            const dataSource = [
	{name:'基地5',value:580},
	{name:'基地1',value:536},
	{name:'基地2',value:500},
	{name:'基地3',value:350},
	{name:'基地4',value:300},
	{name:'基地8',value:280},
	{name:'基地6',value:240},
	{name:'基地7',value:200},
];
     let barWidth = 10 /* 进度条及进度条radius宽度 */,
        nameWidth = 60 /* 进度条名称宽度 */,
        unit = '人' /* 单位 */,
        attaData = [] /* 进度条数据 */,
        attaVal = [] /* 进度条数值 */,
        topName = [] /* 进度条名称 */,
        salvProMax = []; /* 背景条数据 */
     dataSource.forEach((it, i) => {
        // let itemStyle = {
        //     color: i > 3 ? attackSourcesColor[3] : attackSourcesColor[i],
        // };
        topName[i] = `${it.name}`;
        attaVal[i] = it.value;
        attaData[i] = {
            value: parseFloat(it.value).toFixed(2),
            // itemStyle: itemStyle,
        };
    });
    /* 该值无具体作用,取进度最大值 * 1.2 */
    salvProMax = Array(attaVal.length).fill(Math.max(...attaVal) * 1.2);
     const img3 =
        '';
     const img2 = '';
     const img1 = '';
     const img4 = ''
     option = {
        backgroundColor:'#000',
        grid: [
           {
              left: 0,
              top: 40,
              right: 10,
              bottom: 40,
              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, 40, -20],
                 align: 'left',
                 formatter: (name, index) => {
                    const id = index + 1;
                    if (id < 4) {
                        return `{icon${id}|}`;
                     } else {
                        return `{count|${id}}`;
                     }
                 },
                 rich: {
                    icon1: {
                        width: 20,
                       height: 20,
                       align: 'center',
                       borderRadius: 50,
                       backgroundColor: {
                          image: img1,
                       },
                        
                    },
                    icon2: {
                       width: 20,
                       height: 20,
                       align: 'center',
                       borderRadius: 50,
                       backgroundColor: {
                          image: img2,
                       },
                    },
                    icon3: {
                       width: 20,
                       height: 20,
                       shadowColor: '#3374ba',
                       borderColor: '#3374ba',
                       borderWidth: 1,
                       borderRadius: 50,
                       align: 'center',
                       backgroundColor: {
                          image: img3,
                       },
                    },
                    count: {
                       padding: [2, 0, 0, 0],
                       width: 20,
                       height: 18,
                       color: '#fff',
                       align: 'center',
                       fontSize: 12,
                       fontFamily: 'DIN',
                       fontWeight: 500,
                       shadowColor: '#008AFF',
                       borderColor: '#008AFF',
                       borderRadius: 50,
                       borderWidth: 1,
                       backgroundColor: {
                        image: img4,
                     },
                    },
                    name: {
                       width: 80,
                       fontSize: 12,
                       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, 40],
                 align: 'left',
                 formatter: (name, index) => {
                    return `{value|${name}}`;
                 },
                 rich: {
                    value: {
                       color: '#fff',
                       fontSize: 12,
                       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}吨}`;
                 },
                 rich: {
                    value: {
                       color: '#fff',
                       fontSize: 12,
                       fontWeight: 500,
                    },
                 },
              },
           },
        ],
        series: [
           {
              z: 1,
              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],
                    barBorderRadius: [30, 30, 30, 30],
                    color: new echarts.graphic.LinearGradient(
                       0,
                       0,
                       1,
                       0,
                       [
                          {
                             offset: 0,
                             color: '#01A6EB', // 0% 处的颜色
                          },
                          {
                             offset: 1,
                             color: '#005CD8', // 100% 处的颜色
                          },
                       ],
                       false
                    ),
                 },
              },
           },
           {
              z: 3,
              name: '背景',
              type: 'bar',
              barWidth: 10,
              barGap: '-100%',
              data: salvProMax,
              itemStyle: {
                 normal: {
                    color: 'rgba(131, 132, 132, 0.1)',
                    barBorderRadius: [30, 30, 30, 30],
                    borderColor:'#004FBB'
                 },
              },
           },
        ],
     };