let bgSvg = '' var category = [ "东北", "华东", "华中", "西南", "华北" ]; var barData = [{ "name": "低危", "color": "#3ca418", "value": [10,41,22,92,72] }, { "name": "中危", "color": "#31d0e9", "value": [64,40,24,97,39] }, { "name": "高危", "color": "#ed902c", "value": [69,36,58,49,90] }, { "name": "危急", "color": "#d8436b", "value": [94,7,67,33,20] } ] 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: [40, 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: '#0A1934', grid: { top: 30, left: 30, right: 30, bottom: 90 }, xAxis: { data: category, show: true, axisLabel: { color: '#fff', formatter: (value, index) => { return [ '{title|'+ value + '}' ].join('\n') }, rich: { title: { color: '#eee', align: 'center', lineHeight: 40 }, } }, axisLine: { show: false }, splitLine: { show: false }, }, yAxis: { show: false, splitLine: { show: false }, axisLine: { show: false }, axisLabel: { color: '#fff' } }, series: [].concat( { data: backgroundData, type: 'pictorialBar', symbol: 'image://' + bgSvg, symbolOffset: ['-45%', 10], z: -100 }, seriesData), animation: true };