【ECharts】柱状图

【ECharts】柱状图大家好 我是宾果的救星 希望记录的学习和收获能够帮助大家在开发过程中得到思路并且解决难题

大家好,欢迎来到IT知识分享网。

目录

柱状圆角

label显示位置

数值为0不展示0

悬浮显示数据线

悬浮柱状渐变色

每个柱的颜色

单个柱的颜色

柱子重叠

柱子堆叠

柱子背景

柱子顶部加入图片效果

仿3D柱状图

竖向柱状改成横向柱状


柱状圆角

柱子的顶部是圆角。主要是 barBorderRadius: [50, 50, 0, 0]。分别对应的是:左上,右上,右下,左下。

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [{ data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', itemStyle: { normal: { barBorderRadius: [50, 50, 0, 0], // 左上,右上,右下,左下 } } }] };

label显示位置

label显示在柱子中间,主要是position: ‘inside’ 起到的作用。

语义声明位置:

  • top
  • bottom
  • left
  • right
  • inside
  • insideTop
  • insideBottom
  • insideLeft
  • insideRight
  • insideTopLeft
  • insideTopRight
  • insideBottomLeft
  • insideBottomRight

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [{ data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', label: { normal: { show: true, position: 'inside' } }, }] };

相对的百分比:

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', label: { show: true, position: ['10%', '10%'], }, } ] };

绝对像素值:

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', label: { show: true, position: [10, 100], }, } ] };

数值为0不展示0

数据为0的时候展示在坐标轴线上很丑。可以控制为0的值直接展示空字符串’ ‘。

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [120, 0, 150, 80, 0, 110, 130], type: 'bar', label:{ normal:{ show:true, formatter:function (params) { if (params.value > 0){ return params.value; } else { return '' } } } } } ] };

悬浮显示数据线

【ECharts】柱状图

option = { grid: { left: '2%', top: '10%', right:0, bottom:'5%', containLabel: true//grid 区域是否包含坐标轴的刻度标签。 }, tooltip : { trigger: 'axis', // 坐标轴悬浮 axisPointer: { type: 'cross', label: { backgroundColor: '#B248CA' } } }, xAxis : [ { type : 'category', data : ['优秀', '良好', '合格', '未合格', '不及格', '零分'], axisTick: { //坐标轴刻度 show:true, alignWithLabel: true//刻度和文字对齐 }, nameLocation:'start',//坐标轴名称显示位置 nameGap:'9',//坐标轴名称与轴线之间的距离。 boundaryGap:['1%','4%'],//不从0%开始 textStyle:{ width:'54' }, axisLabel:{ interval:0,//文字间没有间隔 rotate:'45', formatter : function(params){//五个字一行 var newParamsName = ""; var paramsNameNumber = params.length; var provideNumber = 5; 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 = params.substring(start, end) + "\n"; } newParamsName += tempStr;// 最终拼成的字符串 } } else { newParamsName = params; } return newParamsName }, formatter:function(value) { //文字竖直显示 return value.split("").join("\n"); } , formatter : function(params,index){//隔一个换行 if (index % 2 != 0) { return '\n\n' + params; } else { return params; } } } } ], yAxis : [ { type : 'value', axisLabel: { show: true, formatter: '{value} %' }, } ], series : [ { name:'直接访问', type:'bar', barWidth: '6', barGap:'56', data:[56, '38', '42','65', '99',{//设置个别颜色 value:'40', itemStyle:{ color:'black', } }], itemStyle:{ normal:{ barBorderRadius:[7,7,0,0],//圆柱圆角 color: function (params){ //不同颜色 var colorList = ['#50E9C8','#F03869','#AC91DF','#F3CE30','#31B5EC','#D96C70']; return colorList[params.dataIndex]; }, color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{//渐变色 offset: 0, color: '#FAD036' }, { offset: 1, color: '#EF2409' }]), } } } ] }

悬浮柱状渐变色

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [{ data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#83bff6' }, { offset: 0.5, color: '#188df0' }, { offset: 1, color: '#188df0' }]) }, emphasis: { // 鼠标悬浮 color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: '#2378f7' }, { offset: 0.5, color: '#83bff6' }, { offset: 1, color: '#2378f7' }]) } } }] };

每个柱的颜色

【ECharts】柱状图

let colors = ['lightgreen','pink','purple','orange','lightblue'] option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri'] }, yAxis: { type: 'value' }, series: [ { color: colors, data: [120, 200, 150, 80, 70], type: 'bar', itemStyle: { normal: { color: function(params) { let idx = params.dataIndex return colors[idx] }, } }, } ] };

单个柱的颜色

【ECharts】柱状图

方法一:更推荐 

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', itemStyle: { normal: { color:(val) => { if (val.value < 80) { return '#F7782C' } else{ return '#5470c6' } }, }, }, } ] };

方法二:

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { type: 'bar', data: [120, 200, 150, 80, { value: 70, itemStyle:{ color: '#F7782C' } }, 110, 130], } ] };

柱子重叠

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], }, yAxis: { type: 'value' }, series: [ { data: [20, 120, 130, 60, 80, 100, 100], type: 'bar' }, { data: [130, 202, 180, 80, 90, 200, 130], type: 'bar', barGap:'-100%',// 第二个柱子的位置实现重叠 z:'-1',// 柱子的层级 } ] };

柱子堆叠

【ECharts】柱状图

let colors = [ "#FC4540", new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: "#00C6FF" }, { offset: 1, color: "#003B87" }, ]), ]; option = { color: colors, xAxis: { type: "category", data: ['1月','2月','3月','4月','5月','6月'], }, yAxis: { type: "value", }, series: [ { name: "男", data: [1,2,3,4,5,6], type: "bar", stack: "total", barWidth: 36, label: { show: true, position: "outside", color: "#fff", formatter: function (params) { if (params.value > 0) { return params.value; } else { return ""; } }, }, }, { name: "女", data: [3,2,1,1,1,1], type: "bar", stack: "total", barWidth: 36, label: { show: true, position: "outside", color: "#00C6FF", formatter: function (params) { if (params.value > 0) { return params.value; } else { return ""; } }, }, }, ], };

柱子背景

【ECharts】柱状图

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], }, yAxis: { type: 'value' }, series: [ { data: [20, 120, 130, 60, 80, 100, 100], type: 'bar' }, { data: [130, 202, 180, 80, 90, 200, 130], type: 'bar', barWidth: '60%', //俩柱之间的距离 showBackground: true, //柱状背景 backgroundStyle: { color: 'rgba(180, 180, 180, 0.2)' } } ] };

柱子顶部加入图片效果

【ECharts】柱状图

let circleList = [ 'image://', 'image://' ] // 设置每个状图颜色 var colorList = ['#FCD298', '#24FDE7', '#24FDE7', '#24FDE7', '#24FDE7', '#24FDE7', '#24FDE7']; option = { xAxis: { show: false, type: 'value' }, yAxis: [{ type: 'category', inverse: true, axisLabel: { show: true, textStyle: { color: '#B9E4E6' }, }, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, data: ['Brazil', 'Indonesia', 'USA', 'India', 'China'] }, ], backgroundColor: 'rgb(49,69,81)', series: [ // 渐变线条 { type: 'bar', zlevel: 1, itemStyle: { data: [50, 28, 17, 38, 90], normal: { barBorderRadius: 0, color: function (params) { // 大于等于50%的是黄色 反之为蓝色 var colorItem if (params.data >= 50) { colorItem = ['rgba(252, 210, 152, .2)', 'rgba(252, 210, 152, 1)']; } else { colorItem = ['rgba(36, 253, 231, .2)', 'rgba(36, 253, 231, 1)']; } // 设置线条渐变色 return new echarts.graphic.LinearGradient(0, 0, 1, 0, [{ offset: 0, color: colorItem[0] }, { offset: 1, color: colorItem[1] } ], false); } }, }, barWidth: 4, data:[50, 28, 17, 38, 90] }, // 圆点 { type: 'pictorialBar', symbol: function (params, value) { // 设置图片 if (params >= 50) return circleList[0] return circleList[1] }, symbolPosition: 'end', symbolSize: [30, 30], symbolOffset: [10, 0], z: 20, data: [50, 28, 17, 38, 90] } ] }; 

参考:Vue中Echarts柱状图如何自定义顶部亮点

仿3D柱状图

【ECharts】柱状图

var data1 = [200, 100, 200, 50, 100]; var data2 = [300, 200, 300, 200, 400]; option = { backgroundColor: 'rgb(49,69,81)', xAxis: { data: ['北京', '上海', '深圳', '广州', '杭州'], splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: false, } }, yAxis: { splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: false, } }, series: [ // 底部的光晕 { name: '', type: 'pictorialBar', tooltip: { show: false }, symbolSize: [90, 40], symbolOffset: [0, 20], z: 1, itemStyle: { normal: { color: 'transparent', borderColor: '#26B2E8', borderType: 'solid', borderWidth: 4 } }, data: [1, 1, 1, 1, 1] }, // 底部圆片 { name: '', type: 'pictorialBar', symbolSize: [45, 25], symbolOffset: [0, 10], z: 12, itemStyle: { opacity: 1, color: '#FFD56E' }, data: [0, 0, 0, 0, 0] }, { name: '2022', type: 'bar', barWidth: 45, barGap: '-100%', itemStyle: { color: function (params) { var a = params.name.slice(0, 2); return new echarts.graphic.LinearGradient( 0, 0, 0, 1, [ { offset: 0, color: '#FF9A22' // 0% 处的颜色 }, { offset: 1, color: '#FFD56E' // 100% 处的颜色 } ], false ); } }, data: data1 }, // 顶部圆片 { name: '', type: 'pictorialBar', symbolSize: [45, 25], symbolOffset: [0, -10], z: 12, itemStyle: { opacity: 1, color: '#f00' }, symbolPosition: 'end', data: data1 }, ] }; 

参考链接:echarts 3D 柱状图

竖向柱状改成横向柱状

xAxis yAxis 的内容互换。

竖向柱状

option = { xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, yAxis: { type: 'value' }, series: [ { data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', } ] };

横向柱状

option = { xAxis: { type: 'value', }, yAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] }, series: [ { data: [120, 200, 150, 80, 70, 110, 130], type: 'bar', } ] };

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/141401.html

(0)
上一篇 2025-05-17 16:45
下一篇 2025-05-17 17:00

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信