带图标柱状图

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            let chartData =[
    {"value": 600,"name": "单位1"},
    {"value":500,"name": "单位2"},
    {"value":400,"name": "单位3"},
    {"value": 300,"name": "单位4"},
    {"value": 200,"name": "单位5"},
];

let icon1 = '';
let icon2='';

let colorList  =[
    ['#9ffafa', '#9ffafa', '#9ffafa', '#0093ff'],
    ['#f4ceb9', '#f4ceb9', '#f4ceb9', '#0093ff'],
    ['#b2b4ff', '#b2b4ff', '#b2b4ff', '#0093ff']
]

option = {
    backgroundColor:'#003a82',
    tooltip: {
                    show:false,
                    trigger: 'axis',
                    axisPointer: {
                        type: 'shadow'
                    }
                },
    legend: {
        show: false
    },
    grid: {
        left: '50',
        right:'3%',
        top: '6%',
        bottom:0,
        containLabel:true
    },
    xAxis: {
        show: false,
        type: 'value'

    },
    yAxis: [
        {
            type: 'category',
            inverse: true,
            axisLine: {
                show: false
            },
            axisTick: {
                show: false
            },
            axisPointer: {
                label: {
                    show: true,
                    margin: 5
                }
            },
            data:chartData.map(item => item.name),
            axisLabel: {
                show: false,
                inside: false,
                fontSize: 14,
                color: '#88caef',
            },
        }, 
        {
            type: 'category',
            inverse: true,
            axisTick: 'none',
            axisLine: 'none',
            show: true,
            data: chartData.map(item => item.value),
            axisLabel: {
                show:true,
                fontSize: 14,
                color: '#88caef',
                formatter:'{value}'
            }
        }
    ],
    series: [
        {
            z: 2,
            name: 'value',
            type: 'bar',
            barWidth: 5,
            zlevel: 1,
            data: chartData.map((item, i) => {
                let itemStyle = {
                    color: i > 3 ? colorList[0][3] : colorList[0][i]
                }
                return {
                    value: item.value,
                    itemStyle: itemStyle
                };
            }),
            label: {
                normal: {
                    color: '#b3ccf8',
                    show: true,
                    position: [-30, '-15'],
                    textStyle: {
                        fontSize: 12,
                        color: '#88caef',
                    },
                    rich: {
                    a1: {
                        color: '#fff',
                        fontSize: 16,
                        fontWeight:600,
                        backgroundColor: {
                            image: icon1
                        },
                        width: 20,
                        height: 10,
                        align: 'center',
                        borderRadius: 2
                    },
                    a2: {
                        color: '#fff',
                        fontSize: 16,
                        fontWeight:600,
                        backgroundColor: {
                            image: icon1
                        },
                        width: 20,
                        height: 10,
                        align: 'center',
                        borderRadius: 2
                    },
                    a3: {
                        color: '#fff',
                        fontSize: 16,
                        fontWeight:600,
                        backgroundColor: {
                            image: icon1
                        },
                        width: 20,
                        height: 10,
                        align: 'center',
                        borderRadius: 2
                    },
                    b: {
                        color: '#fff',
                        fontSize: 16,
                        fontWeight:600,
                        backgroundColor: {
                            image:icon2
                        },
                        width: 20,
                        height: 10,
                        align: 'center',
                        borderRadius: 2
                    }
                },
                    formatter: (a,b)=> {
                        var index = chartData.map(item => item.name).indexOf(a.name) ;
                        index = index + 1;
                        if (index - 1 < 3) {
                            return [
                                '{a' + index + '|' + index + '}' + '  ' + a.name
                            ].join('\n')
                        } else {
                            return [
                                '{b|' + index + '}' + '  ' + a.name
                            ].join('\n')
                        }
                    }
                }
            },
        },
        {
            name: '总量',
            type: 'bar',
            barWidth: 5,
            barGap: '-100%',
            itemStyle: {
                normal: {
                    color: 'rgba(32, 48, 85, 0.55)'
                }
            },
            data: (new Array(chartData.length)).fill(chartData[0].value+50)
        }

    ]
};