let { yUnit, yData, sData, sData2, colorList, total, percents, units } = { yUnit: "总量", yData: ["one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten"], sData: [170, 82, 105, 42, 58, 110, 169, 58, 132, 90], sData2: [85, 41, 52.5, 21, 58, 110, 169, 58, 132, 90], percents: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0], units: ["1", "俩", "仨", "四", "五", "六", "七", "Ⅷ", "⑨", "Ⅹ"], total: 200, colorList: [ { color: "#249EFF", offset: "0" }, // { color: "#18E796", offset: "0.6" }, { color: "#1E88E5", offset: "1" } ], }; let s2Data = []; for (let i = 0; i < sData.length; i++) { s2Data.push(total * 2); } let colorline = new echarts.graphic.LinearGradient(0, 0, 1, 0, colorList); option = { grid: { left: 30, right: 30, top: 0, bottom: 0, containLabel: true }, tooltip: { show: true, trigger: "axis", backgroundColor: "rgba(11, 48, 83, 0.47)", borderColor: "#2BDBFB", textStyle: { color: "#fff" }, formatter: function (params, ticket, callback) { let jz = params[0]; let wz = params[2]; let marker = params[params.length - 1].marker; let tool = `${marker}${jz.name}:<br/> 价值量:${jz.value} ${"亿元"}<br/> 功能量:${wz.value} ${wz.data.unit}<br/>`; // let tool = `${marker}${jz.name}:${jz.value}`; return tool; } }, xAxis: [ { type: "value", show: false }, { type: "value", show: false } ], yAxis: [ { type: "category", inverse: true, offset: 5, axisLabel: { show: true, color: "#3D3D3D", fontSize: 14 }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, scale: true, data: yData }, { triggerEvent: true, show: true, inverse: true, data: yData, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { interval: 0, color: ["#3D3D3D"], align: "left", verticalAlign: "center", lineHeight: 40, fontSize: 14, formatter: function (value, index) { // return (sData[index] ? ((sData[index] / total) * 100).toFixed(2) : 0) + "%"; return percents[index]; } } } ], series: [ { type: "pictorialBar", // symbol: 'image://', // symbolSize: [45, 45], symbol: "image://", symbolSize: [30, 30], symbolOffset: [0, 0], symbolPosition: "right", z: 12, itemStyle: { normal: { color: "#C9D9DB" } }, yAxisIndex: 1, data: (function () { var list = []; for (var i = 0; i < sData.length; i++) { list.push(2 * sData[i]); } return list; })() }, { name: "数量", data: sData, type: "bar", smooth: true, showSymbol: false, itemStyle: { color: colorline }, barWidth: "5", label: { normal: { show: false } }, z: 11, emphasis: { lineStyle: { width: 1 } } }, { data: s2Data, type: "bar", smooth: true, showSymbol: false, barWidth: 1, barGap: "-80%", yAxisIndex: 1, itemStyle: { radio: "5px", // color: "rgba(3, 236, 253, 0.3)" color: "rgba(198, 226, 255, 1)" }, label: { normal: { show: false } }, z: 1 }, { // 分隔 type: "pictorialBar", itemStyle: { normal: { color: "#091F48b3" } }, symbolRepeat: "fixed", symbolMargin: 10, //图形的两边间隔 symbol: "rect", symbolClip: true, //是否裁剪图形 symbolSize: [5, 2], barWidth: 1, symbolPosition: "start", //图形的定位位置。 symbolOffset: [-2, 0], //图形相对于原本位置的偏移。 data: s2Data, z: 2, animationEasing: "elasticOut" }, { type: "bar", xAxisIndex: 1, barWidth: 1, barGap: "-80%", itemStyle: { color: "rgba(0, 0, 0, 0)" }, data: sData2.map((val, idx) => ({ value: val, unit: units[idx] })) } ] };