🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
>#### 面积图标线 ~~~ var getname = ['东北师范大学', '北京师范大学', '华东师范大学', '华中师范大学', '陕西师范大学', '西南大学']; var getvalue = [318, 159, 219, 157, 134, 224]; var getvalue1 = [208, 119, 219, 136, 214, 54]; var getvalue2 = [218, 219, 179, 317, 303, 124]; var getvalue3 = [188, 324, 199, 187, 174, 241]; var getvalue4 = [168, 155, 272, 157, 194, 224]; var getvaluesum = []; for (var i = 0; i < getname.length; i++) { getvaluesum[i] = getvalue[i] + getvalue1[i] + getvalue2[i] + getvalue3[i] + getvalue4[i]; } var maxnum = Math.max.apply(null, getvaluesum); var maxlen = Math.pow(10, String(Math.ceil(maxnum)).length - 2); if (maxnum >= 5) { var max = Math.ceil(maxnum / (.95 * maxlen)) * maxlen; } else { var max = 5; } option = { title: { text: '毕业生统计柱状图', left: 'center', top: '10px', textStyle: { color: '#ffffff' } }, grid: { top: '83', right: '15', left: '50', bottom: '55' }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', tooltip: { trigger: 'axis', axisPointer: { type: 'none' }, formatter: '{b0}</br>{a0}本科人数:{c0}人</br>{a1}本科人数:{c1}人</br>{a2}本科人数:{c2}人</br>{a3}本科人数:{c3}人</br>{a4}本科人数:{c4}人' }, legend: { type: "scroll", right: '10', top: '50', data: ['2020级', '2019级', '2018级', '2017级', '2016级'], itemGap: 25, itemWidth: 16, itemHeight: 16, textStyle: { fontSize: '13', color: '#ffffff', }, }, xAxis: [{ data: getname, axisLabel: { //interval: 0, formatter: function (value) { var ret = ""; //拼接加\n返回的类目项 var maxLength = 5; //每项显示文字个数 var valLength = value.length; //X轴类目项的文字个数 var rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数 if (rowN > 1) //如果类目项的文字大于5, { for (var i = 0; i < rowN; i++) { var temp = ""; //每次截取的字符串 var start = i * maxLength; //开始截取的位置 var end = start + maxLength; //结束截取的位置 //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧 temp = value.substring(start, end) + "\n"; ret += temp; //凭借最终的字符串 } return ret; } else { return value; } }, margin: 10, color: '#666666', textStyle: { color: '#ffffff', fontSize: 13, fontWeight: 400 }, }, axisLine: { lineStyle: { color: '#B0C5DB', } }, axisTick: { show: false }, }], yAxis: [{ min: 0, max: max, // 计算最大值 interval: max / 5, // 平均分为5份 splitNumber: 5, name: '单位:人', nameTextStyle: { color: '#ffffff', fontSize: 13, padding: [0, 0, 0, 65] }, axisLabel: { color: '#666666', textStyle: { color: '#ffffff', fontSize: 13, fontWeight: 400 }, }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { lineStyle: { color: '#CCDBEB', type: 'dashed', opacity: 0.5 } } }], series: [{ name: '2020级', type: 'bar', data: getvalue, stack: '各专业本科生年级分布', barWidth: '20px', itemStyle: { normal: { color: { x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: '#63B4FF' // 0% 处的颜色 }, { offset: 1, color: '#1890FF' // 100% 处的颜色 }], }, barBorderRadius: [0, 0, 0, 0], label: { show: true, position: 'top', offset: [15, 20], align: 'left', formatter: function (params) { return params.value; }, textStyle: { fontSize: 12, color: '#ffffff', }, } } }, }, { name: '2019级', type: 'bar', data: getvalue1, stack: '各专业本科生年级分布', barWidth: '20px', itemStyle: { normal: { color: { x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: '#FFD19A' // 0% 处的颜色 }, { offset: 1, color: '#FFD283' // 100% 处的颜色 }], }, barBorderRadius: [0, 0, 0, 0], label: { show: true, position: 'top', offset: [15, 20], align: 'left', formatter: function (params) { return params.value; }, textStyle: { fontSize: 12, color: '#ffffff', }, } } }, }, { name: '2018级', type: 'bar', data: getvalue2, stack: '各专业本科生年级分布', barWidth: '20px', itemStyle: { normal: { color: { x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: '#64F0BC' // 0% 处的颜色 }, { offset: 1, color: '#47D095' // 100% 处的颜色 }], }, barBorderRadius: [0, 0, 0, 0], label: { show: true, position: 'top', offset: [15, 20], align: 'left', formatter: function (params) { return params.value; }, textStyle: { fontSize: 12, color: '#ffffff', }, } } }, }, { name: '2017级', type: 'bar', data: getvalue3, stack: '各专业本科生年级分布', barWidth: '20px', itemStyle: { normal: { color: { x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: '#BDBCFF' // 0% 处的颜色 }, { offset: 1, color: '#9C9BFF' // 100% 处的颜色 }], }, barBorderRadius: [0, 0, 0, 0], label: { show: true, position: 'top', offset: [15, 20], align: 'left', formatter: function (params) { return params.value; }, textStyle: { fontSize: 12, color: '#ffffff', }, } } }, }, { name: '2016级', type: 'bar', data: getvalue4, barWidth: '20px', stack: '各专业本科生年级分布', itemStyle: { normal: { color: { x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: '#FFA387' // 0% 处的颜色 }, { offset: 1, color: '#FF6388' // 100% 处的颜色 }], }, barBorderRadius: [3, 3, 0, 0], label: { show: true, position: 'top', offset: [15, 20], align: 'left', formatter: function (params) { return params.value; }, textStyle: { fontSize: 12, color: '#ffffff', }, } } }, }] }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/e4/33/e433eb36801c84440bf05a56362c5869_800x450.png) <hr> >#### 双条形图 ~~~ var xAxis = ['文学院', '历史文化学院', '哲学与政府管理学院', '马克思主义学院', '教育学院', '美术学院', '外国语学院', '新闻传播学院', '地理学院', '化学学院']; var data1 = [28763, 14237, 10224, 5561, 5677, 5546, 7589, 6521, 4061, 5079]; var data2 = [16.3, 12.6, 11.8, 9.9, 9.5, 9.3, 8.8, 8.7, 6.9, 6.8]; option = { title: { text: '双条形图', left: 'center', top: '10px', textStyle: { color: '#ffffff' } }, grid: { top: '83', right: '15', left: '50', bottom: '55' }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', legend: { data: ['学院借阅总册次', '人均借阅册次'], type: "scroll", height: '88%', left: '19%', top: '8%', itemGap: 274, itemWidth: 10, itemHeight: 10, textStyle: { fontSize: '13', color: '#fff', }, }, tooltip: { show: true, trigger: 'axis', axisPointer: { type: 'shadow' } }, grid: [{ show: false, left: '8%', top: '12%', bottom: '8%', containLabel: true, width: '25%' }, { show: false, left: '50%', top: '12%', bottom: '8%', width: '0%' }, { show: false, right: '8%', top: '12%', bottom: '8%', containLabel: true, width: '25%' } ], xAxis: [{ type: 'value', inverse: true, axisLabel: { show: false, }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { show: false } }, { gridIndex: 1, show: false }, { gridIndex: 2, type: 'value', axisLabel: { show: false, }, axisLine: { show: false }, axisTick: { show: false }, splitLine: { show: false } }], yAxis: [{ type: 'category', inverse: true, position: 'right', data: xAxis, axisLabel: { show: false, }, axisLine: { show: false }, axisTick: { show: false } }, { gridIndex: 1, type: 'category', inverse: true, position: 'center', data: xAxis, axisLine: { show: false }, axisLabel: { show: true, textStyle: { color: "#ffffff", //X轴文字颜色 fontSize: '14', align: 'center', } }, axisTick: { show: false } }, { gridIndex: 2, type: 'category', inverse: true, position: 'left', data: xAxis, axisLabel: { show: false, }, axisLine: { show: false }, axisTick: { show: false } }], series: [{ name: '学院借阅总册次', type: 'bar', barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#6D9BFF' // 0% 处的颜色 }, { offset: 1, color: '#2E64EF' // 100% 处的颜色 }], false), barBorderRadius: [4, 0, 0, 4], } }, label: { show: true, position: 'left' }, data: data1 }, { xAxisIndex: 2, yAxisIndex: 2, name: '人均借阅册次', type: 'bar', barWidth: 8, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#FFAF25' // 0% 处的颜色 }, { offset: 1, color: '#E83D79' // 100% 处的颜色 }], false), barBorderRadius: [0, 4, 4, 0], } }, label: { show: true, position: 'right' }, data: data2 }] }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/cc/e7/cce735b033ec6c0512cf1e26d9991044_800x450.png) <hr> >#### 栅格条形图 ~~~ //当前视口宽度 const nowClientWidth = document.documentElement.clientWidth; // 单位换算方法 function nowSize(val, width = nowClientWidth, initWidth = 1920) { return val * (width / initWidth); } let list = [{ name: '参数4', value: 26.2 }, { name: '参数3', value: 18.0 }, { name: '参数2', value: 24.1 }, { name: '参数1', value: 24.2 }]; let data = ['参数4', '参数3', '参数2', '参数1']; let values = [26.2, 18.0, 24.1, 24.2] option = { title: { top: '10', left: 'center', text: '栅格条形图', textStyle: { align: 'center', color: '#FFFFFF', fontSize: 18, } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', xAxis: { max: 30, splitLine: { show: false }, axisLabel: { show: true, // textStyle: { // fontSize: nowSize(8) // } }, axisTick: { show: true, lineStyle: { "color": "#ccc" } }, axisLine: { show: true, lineStyle: { "color": "#ccc" } }, splitArea: { show: false, } }, grid: { containLabel: true, left: '5%', top: '10%', right: '15%', bottom: '10%' }, yAxis: [{ data: data, inverse: true, axisLine: { show: false }, axisTick: { show: false }, axisLabel: { margin: 10, textStyle: { fontSize: nowSize(15), color: '#ccc' } }, splitArea: { show: false, } }], series: [{ //内 type: 'bar', barWidth: nowSize(20), legendHoverLink: false, symbolRepeat: true, markLine: { data: [{ xAxis: 13, name: '最低警戒值' }, { xAxis: 27, name: '最高警戒值' } ], lineStyle: { color: '#006dd4' } }, silent: true, itemStyle: { color: { type: 'linear', x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: '#00ccff' // 0% 处的颜色 }, { offset: 1, color: '#0061ba' // 100% 处的颜色 }] } }, data: list, z: 1, animationEasing: 'elasticOut' }, { type: 'pictorialBar', animationDuration: 0, symbolRepeat: 'fixed', symbolMargin: nowSize(1), symbol: 'rect', symbolSize: [nowSize(20), nowSize(20)], symbolBoundingData: 30, itemStyle: { normal: { color: 'rgba(0,65,186,0.61)', } }, label: { normal: { show: true, position: 'right', offset: [0, 2], distance: 30, textStyle: { color: '#00ccff', fontSize: 14, } }, }, data: values, z: 0, animationEasing: 'elasticOut' }, { //分隔 type: 'pictorialBar', itemStyle: { color: '#002a66' }, symbolRepeat: 'fixed', symbolMargin: nowSize(10), symbol: 'rect', symbolClip: true, symbolSize: [nowSize(1), nowSize(20)], symbolPosition: 'start', symbolOffset: [0, 0], symbolBoundingData: 30, data: list, z: 2, animationEasing: 'elasticOut' } ] }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/11/d1/11d1f08606e0c261528acb5b1168b35c_800x450.png) <hr> >#### 极坐标柱状图 ~~~ var cw = document.body.clientHeight / 50; var tooltipAxis = { trigger: 'axis', backgroundColor: 'rgba(26,34,126,.9)', padding: 10, borderRadius: 4, textStyle: { fontSize: 12, }, extraCssText: 'box-shadow:0 0 18px rgba(255,255,255,0.2)' } option = { title: { top: '10', left: 'center', text: '极坐标柱状图', textStyle: { align: 'center', color: '#FFFFFF', fontSize: 18, } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', tooltip: tooltipAxis, grid: { top: 80, bottom: 30 }, angleAxis: { type: 'category', data: ['沧市1号储备点', '运河区储备点', '新华区储备点', '泊头市储备点', '任丘市储备点', '黄骅市储备点', '河间市储备点', '海兴县储备点', '南皮县储备点'], splitLine: { // 分隔线 show: false, // 默认显示,属性show控制显示与否 // onGap: null, lineStyle: { // 属性lineStyle(详见lineStyle)控制线条样式 color: ['rgba(207,238,252,0.2)'], width: 1, type: 'solid' } }, axisLine: { // 坐标轴线 show: true, // 默认显示,属性show控制显示与否 lineStyle: { // 属性lineStyle控制线条样式 color: 'rgba(207,238,252,0.2)', width: 1, type: 'solid' }, }, axisTick: { // 坐标轴小标记 show: false, // 属性show控制显示与否,默认不显示 inside: false, // 控制小标记是否在grid里 length: 5, // 属性length控制线长 lineStyle: { // 属性lineStyle控制线条样式 color: 'rgba(207,238,252,0.2)', width: 1 } }, axisLabel: { color: '#fff', fontSize: 1.2 * cw }, }, radiusAxis: { splitLine: { lineStyle: { type: 'solid', color: 'rgba(207,238,252,0.2)' } }, axisLabel: { color: '#fff', fontSize: 1.2 * cw }, axisTick: { // 坐标轴小标记 show: true, // 属性show控制显示与否,默认不显示 inside: false, // 控制小标记是否在grid里 length: 5, // 属性length控制线长 lineStyle: { // 属性lineStyle控制线条样式 color: 'rgba(207,238,252,1)', width: 1 } }, }, polar: { z: 0, center: ['50%', '50%'], radius: ['16%', '80%'], }, series: [{ type: 'bar', data: [12, 24, 33, 44, 43, 45, 41, 41, 43], coordinateSystem: 'polar', name: '存储总量', stack: 'a', color: 'rgba(37,213,232,1)', z: 0, }, { type: 'bar', data: [2, 4, 6, 1, 3, 2, 1, 1, 3], coordinateSystem: 'polar', name: '领用总量', stack: 'a', color: 'rgba(0,100,252,1)', z: 0, }], legend: { show: true, right: 0, top: 0, data: ['存储总量', '领用总量'], icon: 'rect', itemWidth: 10, itemHeight: 10, textStyle: { color: '#fff', } } }; ~~~ > #### 效果图 ![](https://img.kancloud.cn/fe/c8/fec86a5480462f68fe9c531be6bf6927_800x450.png) <hr> >#### 对比柱状图 ~~~ var data = { Amount: ["54300.00", "54014.00", "50034.00", "50034.00", "50034.00", "24004.00", "14334.00"], Province: ['贵州', '山东', '湖南', '黑龙江', '河南', '辽宁省', '北京'] }; //初始化数据 var category = []; var barData = []; var length1 = 7; if (data.Amount.length <= 7) { length1 = data.Amount.length; } for (var i = 0; i < length1; i++) { barData.push(data.Amount[length1 - i - 1]) } for (var i = 0; i < length1; i++) { category.push(data.Province[length1 - i - 1]) } var yMax = 54300; var dataShadow = []; for (var i = 0; i < barData.length; i++) { dataShadow.push(yMax) } let colorList1 = ['#07eef2', '#ebe485', '#ef7e14', '#42dc8b']; option = { title: { top: '10', left: 'center', text: '对比柱状图', textStyle: { align: 'center', color: '#FFFFFF', fontSize: 18, } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', tooltip: { trigger: "axis", axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: "shadow" // 默认为直线,可选为:'line' | 'shadow' } }, grid: { left: "2%", right: "8%", bottom: "10%", top: '10%', //去掉标题,图表整体往上移动 containLabel: true }, xAxis: { type: "value", show: false, //直接设置show|的属性的话x轴的轴线和垂直于它的网格线以及x轴数据会一起显示隐藏,这里需要全部隐藏包括所以直接show,如果需要单独给它们设置显示隐藏详见以下设置 bottom: 2, boundaryGap: ['0%', '1%'], //留白大小,坐标轴1边留白,横向柱状图的右侧label**人不会超出宽度被隐藏 }, yAxis: { boundaryGap: ['0%', '1%'], //留白大小,坐标轴1边留白 axisLabel: { fontSize: 15, color: '#05CCCA', interval: 0, //margin: 95, margin: 15, textStyle: { position: 'topLeft', }, show: false, }, type: "category", data: category, axisTick: { //y轴刻度线 show: false }, axisLine: { //y轴轴线 show: false } }, series: [{ // For shadow name: '最大销售金额', type: 'bar', itemStyle: { normal: { barBorderRadius: 40, color: function (params) { let colorList = ['#002d52', '#292a38', '#28172a', '#0b283f', '#1d074a', '#311535', '#050d4e' ]; return colorList[params.dataIndex]; } }, emphasis: { barBorderRadius: 40 }, }, barGap: '-100%', barCategoryGap: '50%', // barCategoryGap:'40%', data: dataShadow, animation: true, barWidth: 15, label: { formatter: function (param) { for (let i = 0; i < barData.length; i++) { if (param.dataIndex == i) { return barData[i] + "元"; } } }, right: '3%', show: true, textStyle: { fontWeight: 400, fontSize: 14, color: "#069AE6" }, position: "right" }, }, { name: "销售金额", top: 20, color: "#00A6FC", type: "bar", stack: "总量", barCategoryGap: 2, itemStyle: { //通常情况下: normal: { barBorderRadius: 8, //每个柱子的颜色即为colorList数组里的每一项,如果柱子数目多于colorList的长度,则柱子颜色循环使用该数组 color: function (params) { var colorList = [ ['#18579e', '#07eef2'], ['#77633c', '#ebe485'], ['#815529', '#ef7e14'], ['#0d3247', '#42dc8b'], ['#551384', '#810dfc'], ['#734040', '#fb7070'], ['#131d54', '#0141fa'], ]; var index = params.dataIndex; if (params.dataIndex >= colorList.length) { index = params.dataIndex; } return new echarts.graphic.LinearGradient(1, 0, 0, 0, [{ offset: 0, color: colorList[index][1] }, { offset: 1, color: colorList[index][0] } ]); } }, }, label: { formatter: function (param) { for (let i = 0; i < category.length; i++) { if (param.dataIndex == i) { return category[i]; } } }, right: '3%', show: true, offset: [4, -17], textStyle: { fontWeight: 400, fontSize: 15, color: "#4984d5", }, position: "topLeft" }, //设置柱的宽度 barWidth: 15, // height:'70%', data: barData }] } ~~~ >#### 效果图 ![](https://img.kancloud.cn/7f/10/7f1044c884416bbf5728ecb8395183f4_800x450.png) <hr> >#### 月度统计柱状图 ~~~ option = { title: { top: '10', left: 'center', text: '月度统计柱状图', textStyle: { align: 'center', color: '#FFFFFF', fontSize: 18, } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' } }, grid: [{ bottom: "20%" }, { height: 50, bottom: "5%" } ], xAxis: [{ name: "月份", nameTextStyle: { color: "#fff" }, type: 'category', data: ["1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月", ], gridIndex: 0, axisLabel: { color: '#fff' }, axisLine: { lineStyle: { color: '#e7e7e7' } }, axisTick: { lineStyle: { color: '#e7e7e7' } }, zlevel: 2 }, { type: 'category', gridIndex: 1, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, axisLabel: { color: '#fff' }, data: ["一季度", "二季度", "三季度", "四季度"], zlevel: 1 }], yAxis: [{ name: "个数", nameTextStyle: { color: "#fff" }, type: 'value', gridIndex: 0, axisLabel: { color: '#fff' }, splitLine: { lineStyle: { type: 'dashed' } }, axisLine: { lineStyle: { color: '#ccc' } }, axisTick: { lineStyle: { color: '#ccc' } } }, { type: 'value', gridIndex: 1, axisLabel: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false } }], series: [{ data: [86, 87, 9, 4, 27, 99, 17, 67, 75, 47, 105, 123 ], type: 'bar', label: { show: true, position: 'top', textStyle: { color: '#fff' } }, itemStyle: { normal: { color: (params) => { let colors = ['#a7bee1', '#a7bee1', '#a7bee1', '#d3c688', '#d3c688', '#d3c688', '#8a9f8e', '#8a9f8e', '#8a9f8e', '#f68c60', '#f68c60', '#f68c60' ] return colors[params.dataIndex] } } }, xAxisIndex: 0, yAxisIndex: 0 }, { data: [182, 132, 159, 239 ], type: 'bar', label: { show: true, position: 'inside', textStyle: { color: '#fff' } }, itemStyle: { normal: { color: (params) => { let colors = ['#a7bee1', '#d3c688', '#8a9f8e', '#f68c60'] return colors[params.dataIndex] } } }, barWidth: '100%', xAxisIndex: 1, yAxisIndex: 1 } ] }; ~~~ > #### 效果图 ![](https://img.kancloud.cn/9d/e8/9de82726c999d8142840652fe093c1a8_800x450.png) <hr> >#### 组柱状图 ~~~ option = { title: { bottom: '10', left: 'center', text: '组柱状图', textStyle: { align: 'center', color: '#FFFFFF', fontSize: 18, } }, legend: { data: [ '3-11岁任务数', '3-11岁全程接种量', '60岁任务数', '60岁全程接种量', '80岁任务数', '80岁全程接种量', '完成率' ], top: 10, textStyle: { color: '#ffffff' } }, xAxis: { type: 'category', data: ['街道1', '街道2', '街道3', '街道4', '街道5', '街道6', '街道7'], axisLine: { lineStyle: { color: '#fff' } } }, yAxis: [{ type: 'value', axisLine: { lineStyle: { color: '#fff' } } }, { type: 'value', name: '', nameTextStyle: { color: '#fff', padding: [0, 0, 10, -30] }, splitNumber: 5, splitLine: { show: true, lineStyle: { type: 'dashed', width: 1, // 使用深浅的间隔色 color: ['#566471', '#566471'] } }, axisLabel: { show: true, textStyle: { fontSize: 12, color: '#fff' } } } ], toolbox: { feature: { saveAsImage: {} } }, backgroundColor: '#0f375f', tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' }, textStyle: { color: '#fff', align: 'left', fontSize: 14 }, axisLine: { //x坐标轴轴线 show: true, lineStyle: { //x坐标轴轴线样式 color: '#000', //'#ccc' | 'rgb(128, 128, 128)' | 'rgba(128, 128, 128, 0.5)',设置标签颜色 } }, backgroundColor: 'rgba(0,0,0,0.8)', formatter: function (params) { console.log(params); let str = params[0].name + '<br />'; console.log(str); params.forEach((item) => { console.log(item.seriesName); if (item.value) { if (item.seriesName.indexOf('岁全程接种量') != -1) { str += `<span style="display:inline-block;margin-right:5px;border-radius:50%;width:10px;height:10px;left:5px;background-color: ${item.color}"></span> ${item.seriesName}:${item.value}人 <br/>&nbsp; &nbsp; 全程完成率: ${item.value / 100}%<br/><br/>`; } else if (item.seriesName.indexOf('岁任务数') != -1) { str += `<span style="display:inline-block;margin-right:5px;border-radius:50%;width:10px;height:10px;left:5px;background-color: ${item.color}"></span> ${item.seriesName}:${item.value}人<br/>`; } else { str += `<span style="display:inline-block;margin-right:5px;border-radius:50%;width:10px;height:10px;left:5px;background-color: ${item.color} "></span> ${item.seriesName}:${item.value}%<br/>`; } } }); return str; } }, series: [{ name: '3-11岁任务数', data: [150, 230, 224, 218, 135, 147, 260], stack: 'BB', type: 'bar' }, { name: '3-11岁全程接种量', data: [150, 230, 224, 218, 135, 147, 260], stack: 'BB', type: 'bar' }, { name: '60岁任务数', data: [150, 230, 224, 218, 135, 147, 260], stack: 'AA', type: 'bar' }, { name: '60岁全程接种量', data: [880, 30, 124, 118, 35, 47, 160], stack: 'AA', type: 'bar' }, { name: '80岁任务数', data: [660, 30, 124, 118, 35, 47, 160], stack: 'Ad', type: 'bar' }, { name: '80岁全程接种量', data: [880, 30, 124, 118, 35, 47, 160], stack: 'Ad', type: 'bar' }, { name: '完成率', data: [50, 30, 24, 18, 35, 47, 60], yAxisIndex: 1, type: 'line', markLine: { symbol: 'none', itemStyle: { normal: { lineStyle: { type: 'dotted' } } }, data: [{ type: 'average', name: 'Avg' + '%' }] }, // symbol: 'none', itemStyle: { normal: { lineStyle: { width: 2, type: 'solid' //'dotted'虚线 'solid'实线 } } } } ] }; ~~~ > #### 效果图 ![](https://img.kancloud.cn/67/dd/67dd0ffe086e492874246b227b00cdf6_800x450.png) <hr> >#### 图标柱状图 ~~~ // 颜色 var lightBlue = { type: 'linear', x: 0, y: 0, x2: 0, y2: 1, colorStops: [{ offset: 0, color: 'rgba(41, 121, 255, 1)' // 0% 处的颜色 }, { offset: 1, color: 'rgba(0, 192, 255, 1)' // 100% 处的颜色 }], globalCoord: false // 缺省为 false } // 纹理 var piePane = '' var piePatternImg = new Image(); piePatternImg.src = piePane; // 图标 var cpu = 'image://'; var memory = 'image://'; var disk = 'image://'; // 指定图表的配置项和数据 option = { title: { text: '图标柱状图', left: 'center', top: '10px', textStyle: { color: '#ffffff' } }, tooltip: { show: false }, grid: { top: '32%', left: '5%', right: '5%', bottom: '15%', }, xAxis: { data: ['平均CPU\n利用率', '平均内存\n利用率', '平均硬盘\n利用率'], offset: 15, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { color: '#fff', fontSize: 14 } }, yAxis: { min: 0, max: 100, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: false } }, series: [{ type: 'bar', label: { show: true, position: 'top', padding: 10, color: '#2979ff', fontSize: 14, formatter: '{c}%' }, itemStyle: { color: lightBlue }, barWidth: '40%', data: [49, 80, 67], z: 10 }, { type: 'bar', barGap: '-100%', itemStyle: { color: { image: piePatternImg, repeat: 'repeat' }, opacity: 0.05 }, barWidth: '40%', data: [100, 100, 100], z: 5 }, { type: 'bar', barGap: '-100%', itemStyle: { color: '#536dfe', opacity: 0.2 }, barWidth: '40%', data: [100, 100, 100], z: 5 }, { name: 'glyph', type: 'pictorialBar', barGap: '-100%', symbolPosition: 'end', symbolSize: 64, symbolOffset: [0, '-150%'], data: [{ value: 100, symbol: cpu, }, { value: 100, symbol: memory, }, { value: 100, symbol: disk, }] }], backgroundColor: "#0f375f", toolbox: { feature: { saveAsImage: {} } } }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/29/92/2992d75f4d173c3e3485e820fa596be4_800x450.png) <hr> >#### x軸文字竪向排列 ~~~ option = { title: { text: 'x軸文字竪向排列', left: 'center', top: '10px', textStyle: { color: '#ffffff' } }, toolbox: { feature: { saveAsImage: {} } }, backgroundColor: "#0f375f", tooltip: { trigger: 'axis', axisPointer: { type: 'shadow', }, }, grid: { left: '2%', bottom: '3%', containLabel: true, }, xAxis: [{ type: 'category', axisTick: { show: true }, axisLabel: { interval: "auto", lineHeight: 18, fontSize: 12, color: '#ffffff', margin: 10, formatter: function (params) { var newParamsName = ''; var paramsNameNumber = params.length; var provideNumber = 1; //一行显示几个字 var rowNumber = Math.ceil(paramsNameNumber / provideNumber); if (paramsNameNumber > provideNumber) { for (var p = 0; p < rowNumber; p++) { var tempStr = ''; var start = p * provideNumber; var end = start + provideNumber; if (p == rowNumber - 1) { tempStr = params.substring(start, paramsNameNumber); } else { tempStr = '\xa0' + params.substring(start, end) + ' \n'; } newParamsName += tempStr; } } else { newParamsName = params; } return newParamsName; } }, axisLine: { // 轴线 lineStyle: { color: "#ffffff", width: 1, }, }, data: ['一级必达转队', '二级必达转队', '三级必达转队', '一级必达转队', '二级必达转队', '三级必达转队', '一级必达转队', '二级必达转队', '三级必达转队', '一级必达转队', '二级必达转队', '三级必达转队' ], }, ], yAxis: [{ type: 'value', // 修改y轴分割线 splitLine: { lineStyle: { color: '#e6e6e6', type: 'dashed', }, }, axisLabel: { interval: "auto", lineHeight: 18, fontSize: 12, color: '#ffffff', } }, ], series: [{ type: 'bar', barWidth: 35, emphasis: { focus: 'series', }, data: [250, 600, 420, 250, 600, 420, 250, 600, 420, 250, 600, 420], itemStyle: { normal: { //这里是重点 color: function (params) { //注意,如果颜色太少的话,后面颜色不会自动循环,最好多定义几个颜色 var colorList = ['#39B3FF', '#47E0E0', '#7891D9', '#83D978', '#C7A530', '#FF8439','#3BA272','#73C0DE','#EE6666','#FAC858','#91CC75','#5470C6' ]; //给大于颜色数量的柱体添加循环颜色的判断 let lindex = params.dataIndex; if (params.dataIndex >= colorList.length) { lindex = params.dataIndex - colorList.length; } return colorList[lindex] } } } }, ], }; ~~~ >#### 效果图 ![](https://img.kancloud.cn/83/37/8337bfd2d0a24e47e1e43376903083ef_800x450.png) <hr>