基于本人最近在参与研究公司echarts报表部分的功能,其中遇到了很多的坑,这里将echarts异步加载json数据中涉及到的多个series加载实例问题解决方案作一个共享。json
咱们在加载echarts复杂图形时,好比说折线图和柱状图结合,会涉及到多个series样式,给个例子, bash
option = {
tooltip: {
trigger: 'axis',
formatter: function(params, ticket, callback) {
var res = params[0].name;
for (var i = 0, l = params.length; i < l; i++) {
if (params[i].seriesType === 'line') {
res += '<br/>' + params[i].seriesName + ' : ' + (params[i].value ? params[i].value : '-') + 'h';
} else {
res += '<br/>' + params[i].seriesName + ' : ' + (params[i].value ? params[i].value : '-') + '个';
}
}
return res;
}
},
grid: {
containLabel: true
},
legend: {
data: ['时间', '人均个数', '整体个数']
},
xAxis: [{
type: 'category',
axisTick: {
alignWithLabel: true
},
data: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月']
}],
dataZoom: [{
type: 'slider',
xAxisIndex: 0,
filterMode: 'empty',
start: 0,
end: 100
}, {
type: 'slider',
yAxisIndex: 0,
filterMode: 'empty',
start: 0,
end: 100
}, {
type: 'inside',
xAxisIndex: 0,
filterMode: 'empty',
start: 0,
end: 100
}, {
type: 'inside',
yAxisIndex: 0,
filterMode: 'empty',
start: 0,
end: 100
}],
yAxis: [{
type: 'value',
name: '时间',
min: 0,
position: 'left',
axisLabel: {
formatter: '{value} h'
}
}, {
type: 'value',
name: '个数',
min: 0,
position: 'right',
axisLabel: {
formatter: '{value} 个'
}
}],
series: [{
name: '时间',
type: 'line',
label: {
normal: {
show: true,
position: 'top',
}
},
lineStyle: {
normal: {
width: 3,
shadowColor: 'rgba(0,0,0,0.4)',
shadowBlur: 10,
shadowOffsetY: 10
}
},
data: [1, 13, 37, 35, 15, 13, 25, 21, 6, 45, 32, 2]
}, {
name: '人均个数',
type: 'bar',
yAxisIndex: 1,
label: {
normal: {
show: true,
position: 'top'
}
},
data: [22, 22, 23, 77, 24, 55, 55, 89, 98, 164, 106, 224]
}, {
name: '整体个数',
type: 'bar',
yAxisIndex: 1,
label: {
normal: {
show: true,
position: 'top'
}
},
data: [201, 222, 223, 777, 244, 255, 555, 879, 938, 1364, 1806, 2324]
}]
};
复制代码
咱们发现这个echarts图表是双y轴而且由柱状图和折线图组成。时间是用折线图表示的,人均个数和整体个数是由柱状图表示的。而且这是写死的样例,那么咱们实际应用中的数据确定是用异步加载的方式加载数据的,json串的数据格式是同样的,这种不一样的series如何用json串异步加载呢?echarts
这里,楼主用本身所作的项目为例,贴出核心代码。首先,获取到的json串格式如图。total的数据格式头是data。即:data:{total:{date:...}}dom
var option = {
title: {
text: '交易量统计趋势图'
},
tooltip: {
trigger: 'axis',
axisPointer: { // 坐标轴指示器,坐标轴触发有效
type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
},
formatter: function (params, ticket,callback){
var res = params[0].name;
for (var i = 0, l = params.length; i < l; i++) {
if (params[i].seriesType === 'line') {
res += '<br/>' + params[i].seriesName + ' : ' + (params[i].value ? params[i].value : '-') + '元';
} else {
res += '<br/>' + params[i].seriesName + ' : ' + (params[i].value ? params[i].value : '-') + '元';
}
}
return res;
}
},
legend: {
data: [],
align: 'right',
right: 10
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
xAxis: [{
type: 'category',
data: []
}],
yAxis: [{
type: 'value',
name: '总价(元)',
axisLabel: {
formatter: '{value}'
}
}],
series: []
};
复制代码
其次,须要加载数据的3个地方legend(表示图例组件),xAxis(表示x轴数据),series(图表类型和样式等)所有设置为默认,前期的准备工做就这样作好了。 而后,咱们的核心代码来了,最终咱们要实现的效果是让series有2个不一样的图表类型。那么,这里咱们分别定义2个不一样的图表类型,即折线和柱状,即:异步
//表示折线图
var ItemLine = function () {
return {
name: '',
type: 'line',
label: {
normal: {
show: true,
position: 'top',
}
},
lineStyle: {
normal: {
width: 3,
shadowColor: 'rgba(0,0,0,0.4)',
shadowBlur: 10,
shadowOffsetY: 10
}
},
data: []
}
};
//表示柱状图
var ItemBar = function () {
return {
name: '',
type: 'bar',
data: []
}
}
复制代码
定义3个变量分别存储legend,xAxis,series的值。ide
var legends=[];
var xDateArr=[];
var SeriesTotal=[];
复制代码
将json串赋值给3个变量。这里十分重要!十分重要!十分重要!(重要的事情说3遍)。回到咱们刚才的json串,注意,是以data为头的。咱们遍历这个json串:ui
//给x轴赋值
xDataArr=data.total.date;
for (var k in data.total.element) {
//给legend赋值
lengends.push(data.total.element[k].name);
//核心,给series赋值,分开包装的思想。
if (k == 0) {
var itemLine = new ItemLine();
itemLine.name = data.total.element[k].name;
itemLine.data = data.total.element[k].value;
SeriesTotal.push(itemLine);
} else {
var itemBar = new ItemBar();
itemBar.name = data.total.element[k].name;
itemBar.data = data.total.element[k].value;
SeriesTotal.push(itemBar);
}
}
复制代码
固然,我这里是用下标作分割的,小伙伴们也能够用json头等作标志分割2个不一样的series,主要思想是分次包装,这样就能实现series多个系列的数据异步加载了。哪怕3个,4个图例都so easy了~~~ 最后,再把这3个变量赋值给option,并将option加载到dom容器中便可。spa
var myChartTransactionTotal = echarts.init(document.getElementById('main_chart_transaction_total'));
option.legend.data = lengends;
//注意这里是xAxis[0],若是直接写xAxis会报错,由于x轴默认有2个,上半年轴和下半轴。
option.xAxis[0].data = data.total.date;
option.series = SeriesTotal;
//这里最好加上true参数,不然会出现切换图表时前面数据不会清除掉的状况。
myChartTransactionTotal.setOption(option, true);
复制代码
让咱们来看下实际效果,是否是很简单有木有。若是有问题欢迎你们一块儿交流讨论哦!code