带icon百分比条echarts category配置项内容和展示

配置项如下
      var data = [{
        name: '杭州市',
        value: (Math.random() * 100).toFixed(2)
    },
    {
        name: '宁波市',
        value: (Math.random() * 100).toFixed(2)
    },
    {
        name: '温州市',
        value: (Math.random() * 100).toFixed(2)
    },


]

var imgs=[
    '',
    ''
    ,''
]
var colors = [
    {color1:'rgba(31,46,61,1)',color2:'rgba(255,71,71,1)'},
    {color1:'rgba(30,46,61,1)',color2:'rgba(255,101,25,1)'},
    {color1:'rgba(27,42,54,1)',color2:'rgba(205,183,0,1)'},
]
var data = data.sort((a, b) => b.value - a.value);
var max = Math.max(...data.map(item => item.value));
var xAxis = [],
    yAxis = [],
    series = [];
    yAxis.push({
        type: 'category',
        axisLine: {
            show: false
        },
        axisLabel: {
            verticalAlign: 'bottom',
            align: 'left',
            padding: [0, 0, 15, 10],
            color: '#fff',
            fontSize: '16',
            formatter: (p, index) => {
                var sIndex = data.map(item => item.name).indexOf(p);
                return '{index'+index+'|} ' + p;
            },
            rich: {
                index0: {
                    width:20,
                    height:20,
                    backgroundColor:{
                        image:imgs[0]
                    }
                        
                },
                index1: {
                    width:20,
                    height:20,
                    backgroundColor:{
                        image:imgs[1]
                    }
                        
                },
                index2: {
                    width:20,
                    height:20,
                    backgroundColor:{
                        image: imgs[2]
                    } 
                }
            }
        },
        axisTick: {
            show: false
        },
        inverse: true,
        data: data.map(item => item.name)
    })
    yAxis.push({
        type: 'category',
        axisLine: {
            show: false
        },
        axisLabel: {
            verticalAlign: 'bottom',
            align: 'right',
            padding: [0, 0, 15, 10],
            textStyle: {
                color: '#fff',
                fontSize: '26',
            },
            formatter: '{value}'+'件'
        },
        axisTick: {
            show: false
        },
        inverse: true,
        data: data.map(item => item.value)
    })
    series.push({
        type: 'bar',
        barWidth: 10,
        xAxisIndex: 0,
        yAxisIndex: 0,
        zlevel: 1,
        data: data.map((item,i)=>{
            item.itemStyle = {
                color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{
                    offset: 0,
                    color: colors[i].color1 // 0% 处的颜色
                }, {
                    offset: 1,
                    color: colors[i].color2 // 100% 处的颜色
                }], false),
                barBorderRadius: 5
            }
            return item;
        })
    })
    series.push({
        type: 'bar',
        barWidth: 10,
        xAxisIndex: 0,
        yAxisIndex: 1,
        itemStyle: {
            color: 'rgba(50,67,79,1)',
            barBorderRadius: 5
        },
        barGap: '-100%',
        zlevel: 0,
        data: (new Array(data.length)).fill(max)
    })

option = {
    backgroundColor:'rgba(0,0,0,.5)',
    legend: {
        show: false
    },
    tooltip: {
        trigger: 'axis',
        axisPointer: {
            type: 'shadow'
        }
    },
    grid: {
        left: 0,
        top: 0,
        containLabel: true
    },
    yAxis: yAxis,
    xAxis: {
        show: false,
        type: 'value',
        max: max,
        axisLine: {
            show: false
        },
        axisTick: {
            show: false
        },
        splitLine: {
            show: false
        }
    },
    series: series
}
    
截图如下