# 常用功能总结
# echarts常用属性设置
# 线性图颜色渐变
线性渐变,前四个参数分别是 x0, y0, x2, y2, 范围从 0 - 1,相当于在图形包围盒中的百分比,如果 globalCoord 为 `true`,则该四个值是绝对的像素位置
series: [{
name: '工单',
type: 'line',
areaStyle: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [{
offset: 0, color: '#477FE3' // 0% 处的颜色
}, {
offset: 1, color: '#fff' // 100% 处的颜色
}],
global: false // 缺省为 false
}
},
}]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# 柱状图颜色渐变
let echarts = require('echarts/lib/echarts') 需要在对应文件中引用echarts
series: [{
barWidth: 20,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: "#BD5FFF"
},
{
offset: 1,
color: "#477FE3",
}
], false)
}
}
}]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# x轴标签显示
- 倾斜
- 格式化
xAxis: {
axisLabel: {
// interval: 0,
rotate: 40,
margin: 2,
formatter: function(value, index) {
if (value) {
return value.length > 6 ? value.substring(0, 6) + '...' : value
}
},
}
},
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# 饼图 柱状图 小图标形状设置
- 'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow', 'none'
- 通过 'image://url' 设置为图片
'image://http://xxx.xxx.xxx/a/b.png' 'image://...'
legend: {
data: [
{
name: 'Name',
icon: 'circle'
},
{
name: 'Code',
icon: 'rect'
}
]
}
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# 两个y轴显示
- y轴定义两个对象, series中两个对象用于区分y轴,绑定不同数据的属性是 yAxisIndex
- yAxisIndex: 0 和 yAxisIndex: 1
let yAxisData = [
{
name: '件',
nameTextStyle: {
color: '#fff'
},
type: 'value',
axisLabel: {
color: '#fff',
},
axisLine: {
lineStyle: {
color: '#2b6584' // y轴颜色
}
},
splitLine: {
interval: 2,
lineStyle: {
color: '#2b6584',
type: 'dashed'
}
}
},
{
name: '小时',
nameTextStyle: {
color: '#fff'
},
type: 'value',
axisLabel: {
color: '#fff'
},
axisLine: {
lineStyle: {
color: '#2b6584' // y轴颜色
}
},
splitLine: { // 分割线颜色
interval: 2,
lineStyle: {
color: '#2b6584',
type: 'dashed'
}
},
}
]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# 调整图形位置
- grid
grid: [{
left: '10%',
bottom: '10%',
top: '10%',
right: '10%'
}],
1
2
3
4
5
6
2
3
4
5
6
# 柱状图设置柱圆角
- barBorderRadius
itemStyle: {
normal: {
barBorderRadius: [5, 5, 0, 0]
}
}
1
2
3
4
5
2
3
4
5
# 柱状图设置颜色渐变
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#ba7ef3'
}, {
offset: 1,
color: '#965df2'
}
]),
}
},
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# 是否显示刻度线
axisTick: {
show: false
},
1
2
3
2
3
# x轴
- 换行显示 axisLabel.formatter
- x轴坐标全显示 axisLabel.interval 设为0
- x轴线颜色 axisLine.lineStyle
- x轴线透明度 opacity
xAxis: [
{
type: 'category',
data: ['已安装 水、汽监测企业', '已安装 水监测企业', '已安装 气监测企业', '未安装 监测设备企业'], // 一行显示7个字,增加4个空格
axisPointer: {
type: 'shadow'
},
axisLabel: {
formatter:function(params) { // 换行显示
var newParamsName = "";
var paramsNameNumber = params.length;
var provideNumber = 7; // 一行显示几个字
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
},
color: '#2DC2FD',
interval: 0, // x轴坐标全部显示
},
axisLine: {
lineStyle: {
color: '#009CFF'
},
},
splitLine: {
// interval: 2,
show: true,
lineStyle: {
color: 'rgba(0,159,255,0.65)',
type: 'solid',
opacity: 0.65,
}
},
minorTick: {
show: true
},
minorSplitLine: {
show: true,
lineStyle: {
color: 'rgba(0,159,255,0.65)',
opacity: 0.65,
}
}
}
],
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# y轴
- 次分割线 minorSplitLine
yAxis: [
{
name: '',
type: 'value',
nameTextStyle: {
color: '#fff'
},
axisLine: {
show: true,
lineStyle: {
color: '#009CFF' // y轴颜色
}
},
axisTick: {
show: false
},
axisLabel: {
color: '#2DC2FD'
},
splitLine: {
interval: 2,
lineStyle: {
color: 'rgba(0,159,255,0.65)',
type: 'solid',
opacity: 0.65,
}
},
// minorTick: {
// show: true
// },
minorSplitLine: {
show: true,
lineStyle: {
color: 'rgba(0,159,255,0.65)',
opacity: 0.65,
}
}
}
],
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# 柱状图 每个柱颜色设置 及 数据显示在柱状图顶部
series: [
{
name: '',
type: 'pictorialBar',
symbol: 'rect',
symbolSize: [20, 10],
symbolRepeat: true,
areaStyle: {},
data: [this.pandectData.waterAndGasMonitoringNum,
this.pandectData.waterMonitoringNum,
this.pandectData.gasMonitoringNum,
this.pandectData.nonMonitoringNum],
itemStyle: {
normal: {
color: function(params) {
// 定义一个颜色数组
var colorList = ['#2788FF','#2DC2FD','#2DFDD3','#D4D7D8']
return colorList[params.dataIndex]
},
label: { // 数据显示在柱状图顶部
show: true,
position: 'top',
textStyle: {
color: '#CFEFFF',
fontSize: 16
}
}
}
}
}
]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# 饼图颜色设置 及 label样式
- series.label.normal
{a} 系列名
{b} 数据名
{c} 数据值
{d} 百分比
{@xxx} 数据中名为'xxx'纬度的值,如{@product}表示名为'product'的纬度的值
{@[n]} 数据中维度n的值,如{@[3]}` 表示维度 3 的值,从 0 开始计数 - label.position 标签的位置 outside inside center
originalOptions: {
color: ['#37EAA4', '#E03B42', '#FEED5E'],
series: [{
type:'pie',
label: {
normal: {
show: true,
formatter: '{b}({c})', // label 显示格式 xxx(5)
formatter: '{b}({d}%)', // label 显示格式 xxx(50%)
},
},
}]
}
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
# 多条折线图 y轴刻度不准确
- https://github.com/apache/echarts/issues/3808