var nationalImg = '' let bgSvg = '' var category = [ "淮安", "南京", "宿迁", "镇江", "连云港", "大连", "南通", "苏州", "扬州", "无锡", "盐城", "泰州", "常州", ]; var barData = [{ "name": "农房楼龄5年", "color": "#0f4636", "value": [ 10, 41, 22, 92, 72, 10, 41, 22, 92, 72, 92, 72, 10, ] }, { "name": "楼龄5-10年", "color": "#12AF7B", "value": [ 64, 40, 24, 97, 39, 10, 41, 22, 92, 72, 10, 41, 22, ] }, { "name": "楼龄10年以上", "color": "#31d0e9", "value": [ 64, 40, 24, 97, 39, 10, 41, 22, 92, 72, 10, 41, 22, ] }, { "name": "危房", "color": "#C29B10", "value": [ 64, 40, 24, 97, 39, 10, 41, 22, 92, 72, 10, 41, 22, ] } ] let seriesData = barData.map((d, i) => { let arr = [] if (i > 0) { let before = barData[i - 1] arr = d.value.map((v, j) => { let res = v res += before.value[j] d.value[j] = res return res }) } else { arr = d.value } console.log(arr) return { name: d.name, data: arr, type: 'pictorialBar', symbol: 'rect', symbolSize: [10, 8], barWidth: 10, itemStyle: { normal: { barBorderRadius: 52, color: d.color } }, stack: 'all', symbolRepeat: true, animationEasing: 'elasticOut', animationDelay: function(dataIndex, params) { return params.index * 30 * 1.1; }, z: -i } }) let backgroundData = [280, 280, 280, 280, 280] option = { backgroundColor: '#09252e', legend: { data: barData.map((d) => d.name), textStyle: { color: '#fff' } }, grid: { top:100, left: 50, right: 10, bottom:90 }, xAxis: { data: category, show: true, axisLabel: { color: '#fff', formatter: (value, index) => { return [ '{national|}', '{title|'+ value + '}' ].join('\n') }, rich: { title: { color: '#eee', align: 'center', lineHeight: 10 }, national: { height: 20, lineHeight:10 }, } }, axisLine: { show: false }, splitLine: { show: false }, }, yAxis: { show: true, splitLine: { show: false }, axisLine: { show: false }, axisLabel: { show: true, color: '#1381c9' } }, series:seriesData, animation: true };