>#### 面积图标线
~~~
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/> 全程完成率: ${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>
- html
- 头部标签
- canvas
- md
- DOM
- git常用命令
- css
- 网站
- 默认
- 前缀
- 文本
- 图片
- 选择器
- 滚动条
- 强制横屏
- 响应式
- 动画
- animation(动画)
- transition(过渡)
- transform(变形)
- translate(移动)
- 渐变
- 鼠标
- 自定义 Web 字体
- 可视化
- echarts
- 折线图
- 区域颜色标识
- 分段显示不同颜色
- 柱状图
- 子弹图
- 分组、柱体宽度、指示器宽度
- 圓角
- 顶部显示文字
- 双轴柱状折线图
- 双轴双列柱状图
- 单个柱状图
- 多纵向坐标
- 走势图
- 横向百分比
- 最大值和最小值
- 饼图
- 嵌套
- 分组显示
- 饼图结合柱状图
- 折线结合饼图
- 关系图
- 树图
- 地图
- 标点
- 选中
- 常用
- 图片超出可拖拽
- 百度导航
- 短信验证码倒计时
- video
- TS
- 未整理
- 消失的边界线问题
- 跟随
- js
- 兼容
- 数组去重
- 解析 URL 参数为对象
- 图片懒加载
- 正则
- Photoshop
- 快捷键
- 混合模式
- vscode
- vue
- 指令