码迷,mamicode.com
首页 > 其他好文 > 详细

快速基于echarts的大数据可视化

时间:2015-07-09 16:08:19      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:echarts   可视化   大数据   

[Author]: kwu 

快速基于echarts的大数据可视化,echarts纯粹的js实现的图表工具,快速开发的步骤如下:

1、引入echarts的依赖js库

	<script type="text/javascript" src="js/esl/esl.js"></script>
	<script type="text/javascript" src="js/echarts.js"></script>
	<script type="text/javascript" src="js/jquery.js"></script>

2、设置展示的div

	<!-- 为ECharts准备一个具备大小(宽高)的Dom -->
	<div id="main" style="height: 300px"></div>

3、绘图的JS

var myChart;
var option;

// 画图
function drawCharts(echartsHomePath) {
	// 路径配置
	require.config({
		paths : {
			echarts : echartsHomePath +'js'
		}
	})
	
	// 使用
	require([ 'echarts', 'echarts/chart/bar', 'echarts/chart/line' ], function(
			ec) {
		myChart = ec.init(document.getElementById('main'));
		
		
		//官网复制option 开始
		
		
		option = {
			    title : {
			        text: '某地区蒸发量和降水量',
			        subtext: '纯属虚构'
			    },
			    tooltip : {
			        trigger: 'axis'
			    },
			    legend: {
			        data:['蒸发量']
			    },
			    toolbox: {
			        show : true,
			        feature : {
			            mark : {show: true},
			            dataView : {show: true, readOnly: false},
			            magicType : {show: true, type: ['line', 'bar']},
			            restore : {show: true},
			            saveAsImage : {show: true}
			        }
			    },
			    calculable : true,
			    xAxis : [
			        {
			            type : 'category',
			            data : ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
			        }
			    ],
			    yAxis : [
			        {
			            type : 'value'
			        }
			    ],
			    series : [
			        {
			            name:'蒸发量',
			            type:'bar',
			            data:[2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3],
			            markPoint : {
			                data : [
			                    {type : 'max', name: '最大值'},
			                    {type : 'min', name: '最小值'}
			                ]
			            },
			            markLine : {
			                data : [
			                    {type : 'average', name: '平均值'}
			                ]
			            }
			        }
			    ]
			};
			                    
		
		//官网复制option 结束
		myInterval(restPath);
	});
}


//填充数据
function setResult(result, option, myChart) {
	if (result) {
		option.title.text = "每日apputrack趋势图";
		option.title.subtext = "apputrack";
		option.legend.data[0] = "apputrack";
		option.xAxis[0].data = result.day;
		option.series[0].name = "apputrack";
		option.series[0].data = result.cnt;
		myChart.setOption(option);
	}
}


4、ajax获取restful数据

//ajax获取数据
function myInterval(restPath) {
	$.ajax({
		type : 'get',// jquey是不支持post方式跨域的
		async : false,
		url : baseUrl +restPath,  // 跨域请求的URL
		dataType : 'jsonp',
		jsonp : "callback",// 服务端用于接收callback调用的function名的参数
		success : function(result) {
			setResult(result, option, myChart);
		},
		error : function() {
			alert('fail');
		}
	});
}

5、定时调度及参数设置

//ajax获取数据
function myInterval(restPath) {
	$.ajax({
		type : 'get',// jquey是不支持post方式跨域的
		async : false,
		url : baseUrl +restPath,  // 跨域请求的URL
		dataType : 'jsonp',
		jsonp : "callback",// 服务端用于接收callback调用的function名的参数
		success : function(result) {
			setResult(result, option, myChart);
		},
		error : function() {
			alert('fail');
		}
	});
}

展示效果图:

技术分享

版权声明:本文为博主原创文章,未经博主允许不得转载。

快速基于echarts的大数据可视化

标签:echarts   可视化   大数据   

原文地址:http://blog.csdn.net/bdchome/article/details/46817647

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!